아마 지금 데이터베이스의 목록을 쿼리해야 하는 요구 사항이 있을 것입니다. 데이터 테이블은 아마도 다음과 같습니다:
A | B | C | D | E |
1 | 1 | 1 | 2016-08-05 | 40 |
... | ... | ... | ... | ... |
현재 제가 사용하는 SQL 문은 아마도 이렇습니다
<code class="sql">SELECT * FROM `TABLE` WHERE B = 1 AND C = 1 AND D = 2016-08-05 ORDER BY E DESC</code>
이런 경우 쿼리시 히트할 수 있도록 인덱스는 어떻게 생성해야 하나요? index(['B', 'C', 'D', 'E'])
의 복합 색인을 생성할 수 있나요?
아마 지금 데이터베이스의 목록을 쿼리해야 하는 요구 사항이 있을 것입니다. 데이터 테이블은 아마도 다음과 같습니다:
A | B | C | D | E |
1 | 1 | 1 | 2016-08-05 | 40 |
... | ... | ... | ... | ... |
현재 제가 사용하는 SQL 문은 아마도 이렇습니다
<code class="sql">SELECT * FROM `TABLE` WHERE B = 1 AND C = 1 AND D = 2016-08-05 ORDER BY E DESC</code>
이 경우 쿼리에 도달할 수 있도록 인덱스를 어떻게 생성해야 하나요? index(['B', 'C', 'D', 'E'])
의 복합 색인을 생성할 수 있나요?
이론적으로는 인덱스의 왼쪽 접두사 원칙에 따라 B, C, D 세 필드가 순서대로 히트되기 때문에 이렇게 구축할 수 있습니다. 그러나 안타깝게도 E 필드가 정렬에만 사용되는 경우 인덱스는 발동될 수 없습니다.
where 조건에 order by 필드가 나타나면 정렬 작업 없이 인덱스가 사용되기 때문입니다. 다른 경우에는 order by가 정렬 작업을 수행하지 않습니다.
자세한 내용은 이 기사를 읽고 orderby와 index의 관계를 분석할 수 있습니다
http://www.cnblogs.com/zhaoyl...
mysql은 FORCE INDEX 인덱스를 강제로 지정합니다.
SELECT * FROM TABLE1 FORCE INDEX (FIELD1) ...
위의 SQL 문은 FIELD1에 구축된 인덱스만 사용하며 다른 필드의 인덱스는 사용하지 않습니다.