排序使用filesort 时查看是否使用了临时表

2021/5/3 18:25:26

本文主要是介绍排序使用filesort 时查看是否使用了临时表,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

/* 打开 optimizer_trace,只对本线程有效 */

0: SET optimizer_trace="enabled=on";

/* @a 保存 Innodb_rows_read 的初始值 */
1: SELECT VARIABLE_VALUE into @a from performance_schema.session_status where variable_name = 'Innodb_rows_read';

/* 执行语句 */
2:SELECT * from titem where fname > 0 ORDER BY fname ;

/* 查看 OPTIMIZER_TRACE 输出  此处有json*/ 
3:SELECT * FROM INFORMATION_SCHEMA.OPTIMIZER_TRACE;

/* @b 保存 Innodb_rows_read 的当前值 */

4:select VARIABLE_VALUE into @b from performance_schema.session_status where variable_name = 'Innodb_rows_read';

/* 计算 Innodb_rows_read 差值 */
5:select @b-@a;
SET optimizer_trace="enabled=off";

 

可以使用上面一段话来查询json

查出json后搜索关键字

number_of_tmp_files

如果有值 

那便是使用了临时文件



这篇关于排序使用filesort 时查看是否使用了临时表的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程