> 데이터 베이스 > MySQL 튜토리얼 > MySQL索引之隔离列

MySQL索引之隔离列

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-07 17:57:56
원래의
842명이 탐색했습니다.

如果在查询中没有隔离索引的列,mysql通常不会使用索引。隔离列意味着它不是表达式的一部分,也没有位于函数中。 例如: mysqlselect id from test where id +1 =5; 我们能轻易地看出where子句中的id等4,但是mysql却不会帮你求解方程,这取决于自己。我们应

如果在查询中没有隔离索引的列,mysql通常不会使用索引。“隔离“列意味着它不是表达式的一部分,也没有位于函数中。

例如:

mysql>select id from test where id +1 =5;

我们能轻易地看出where子句中的id等4,但是mysql却不会帮你求解方程,这取决于自己。我们应该养成简化where子句的习惯,这样就会把被索引的列单独放在比较运算符的一边。

再例如:

mysql>select ... where TO_DAYS(CURRENT_DATE) - TO_DAYS(date_col)
这个查询会查找date_cool值离今天不超过10天的所有行,但是它不会使用索引,因为使用了TO_DAYS()函数。

稍作修改:

mysql>select ... where data_cool >= DATE_SUB(CURRENT_DATE,INTERVAL 10 DAY);

这个查询就可以使用索引,但是它还可以改进。使用CURRENT_DATE将会阻止查询缓存把结果缓存起来,可以用常量替换掉CURRENT_DATE的值:

mysql>select ... where date_cool >= DATE_SUB('2012-08-29',INTERVAL 10 DAY);
관련 라벨:
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿