>백엔드 개발 >PHP 튜토리얼 >Mysql에서 where와 orderBy 다음에 인덱스를 적중하는 방법을 알려주십시오.

Mysql에서 where와 orderBy 다음에 인덱스를 적중하는 방법을 알려주십시오.

WBOY
WBOY원래의
2016-08-29 08:50:521899검색

아마 지금 데이터베이스의 목록을 쿼리해야 하는 요구 사항이 있을 것입니다. 데이터 테이블은 아마도 다음과 같습니다:

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에 구축된 인덱스만 사용하며 다른 필드의 인덱스는 사용하지 않습니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.