| SELECT * FROM tbl_name WHERE 0; |
| mysql> EXPLAIN SELECT * FROM tbl_name WHERE 0\G *************************** 1. row *************************** id: 1 select_type: SIMPLE table: NULL type: NULL possible_keys: NULL key: NULL key_len: NULL ref: NULL rows: NULL Extra: Impossible WHERE |
| SELECT col3 FROM mytable WHERE col1 = ’some value’ AND col2 = ’some other value’; |
假设col1上的测试匹配了900个数据行,col2上的测试匹配了300个数据行,而同时进行的测试只得到了30个数据行。先测试Col1会有900个数据行,需要检查它们找到其中的30个与col2中的值匹配记录,其中就有870次是失败了。先测试col2会有300个数据行,需要检查它们找到其中的30个与col1中的值匹配的记录,只有270次是失败的,因此需要的计算和磁盘I/O更少。其结果是,优化器会先测试col2,因为这样做开销更小。
![]() | 图解MySQL数据库的安装和操作 | 53815 |
![]() | Mysql数据库操作新手入门,手把手的教会你 | 36326 |
![]() | MySQL入门学习(二)入门篇 | 33066 |
![]() | MySQL入门学习(一)安装篇 | 28468 |
![]() | MY SQL常用命令 | 25482 |
![]() | MySQL入门学习(三)学习篇 | 20922 |
![]() | MySQL入门学习(四)学习篇(2) | 12348 |
![]() | MySQL入门学习(六)修改和备份、批处理 | 8931 |