MySQL 인덱스의 가장 왼쪽 접두사 원칙은 무엇입니까?
머리말
가장 왼쪽에 접두사 인덱스가 있는 이유
최종적으로 분석해 보면 mysql의 데이터베이스 구조 B+트리
실제 문제에서는 예를 들어
index(a, b, c) 세 개의 필드가 있습니다.
쿼리 문 select * from table where c = '1'
을 사용하면 sql 문은 인덱스 인덱스를 사용하지 않습니다. select * from table where c = '1'
,sql语句不会走index索引的
select * from table where b =‘1’ and c ='2'
这个语句也不会走index索引
1. 定义
最左前缀匹配原则:在MySQL建立联合索引时会遵守最左前缀匹配原则,即最左优先,在检索数据时从联合索引的最左边开始匹配
为了更好辨别这种情况,通过建立表格以及索引的情况进行分析
2. 全索引顺序
建立一张表,建立一个联合索引,如果顺序颠倒,其实还是可以识别的,但是一定要有它的全部部分
建立表
CREATE TABLE staffs( id INT PRIMARY KEY AUTO_INCREMENT, `name` VARCHAR(24) NOT NULL DEFAULT'' COMMENT'姓名', `age` INT NOT NULL DEFAULT 0 COMMENT'年龄', `pos` VARCHAR(20) NOT NULL DEFAULT'' COMMENT'职位', `add_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT'入职时间' )CHARSET utf8 COMMENT'员工记录表'; INSERT INTO staffs(`name`,`age`,`pos`,`add_time`) VALUES('z3',22,'manager',NOW()); INSERT INTO staffs(`name`,`age`,`pos`,`add_time`) VALUES('July',23,'dev',NOW()); INSERT INTO staffs(`name`,`age`,`pos`,`add_time`) VALUES('2000',23,'dev',NOW());
建立索引ALTER TABLE staffs ADD INDEX index_staffs_nameAgePos(name,age,pos);
索引的顺序位name-age-pos
显示其索引有没有show index from staffs;
通过颠倒其左右顺序,其执行都是一样的
主要的语句是这三句
explain select *from staffs where name='z3'and age=22 and pos='manager';
explain select *from staffs where pos='manager' and name='z3'and age=22;
explain select *from staffs where age=22 and pos='manager' and name='z3';
以上三者的顺序颠倒,都使用到了联合索引
最主要是因为MySQL中有查询优化器explain,所以sql语句中字段的顺序不需要和联合索引定义的字段顺序相同,查询优化器会判断纠正这条SQL语句以什么样的顺序执行效率高,最后才能生成真正的执行计划
不论以何种顺序都可使用到联合索引
3. 部分索引顺序
3.1 正序
如果是按照顺序(缺胳膊断腿的),都是一样的
explain select *from staffs where name=‘z3’;
explain select *from staffs where name='z3’and age=22;
explain select *from staffs where name='z3’and age=22;
其type都是ref类型,但是其字段长度会有微小变化,也就是它定义的字长长度变化而已
3.2 乱序
如果部分索引的顺序打乱
只查第一个索引
explain select *from staffs where name='z3';
跳过中间的索引
explain select *from staffs where name='z3' and pos='manager';
只查最后的索引
explain select *from staffs where pos='manager';
可以发现正序的时候
如果缺胳膊少腿,也是按照正常的索引
即使跳过了中间的索引,也是可以使用到索引去查询
但是如果只查最后的索引
type就是all类型,直接整个表的查询了(这是因为没有从name一开始匹配,直接匹配pos的话,会显示无序,)
有些时候type就是index类型,这是因为还是可以通过索引进行查询
index是对所有索引树进行扫描,而all是对整个磁盘的数据进行全表扫描
4. 模糊索引
类似模糊索引就会使用到like的语句
所以下面的三条语句
如果复合最左前缀的话,会使用到range或者是index的类型进行索引
explain select *from staffs where name like '3%';
最左前缀索引,类型为index或者rangeexplain select *from staffs where name like '%3%';
类型为all,全表查询explain select *from staffs where name like '%3%';
select * from table where b =‘1’ and c ='2'< /code> 이 문은 인덱스 인덱스로 이동하지 않습니다</li></ol>1. 정의<p><img src="/static/imghw/default1.png" data-src="https://img.php.cn/upload/article/000/000/164/168525475161185.png" class="lazy" alt="MySQL 인덱스의 가장 왼쪽 접두사 원칙은 무엇입니까?" />가장 왼쪽 접두사 일치 원칙: MySQL은 결합 인덱스를 만들 때 가장 왼쪽 접두사 일치 원칙을 따릅니다. 는 공동 인덱스에서 데이터를 검색할 때 가장 왼쪽부터 매칭이 시작됩니다</p><h3 id="이-상황을-더-잘-파악하려면-테이블-및-인덱스-생성-상황을-분석하세요">이 상황을 더 잘 파악하려면 테이블 및 인덱스 생성 상황을 분석하세요</h3><p>2. 전체 인덱스 순서</p><p>테이블을 생성하고 생성합니다. 순서가 반대인 경우에도 식별 가능하지만 모든 부분이 있어야 합니다</p>🎜테이블 생성🎜<div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>CREATE TABLE IF NOT EXISTS article( id INT(10) UNSIGNED NOT NULL PRIMARY KEY AUTO_INCREMENT, author_id INT(10) UNSIGNED NOT NULL, category_id INT(10) UNSIGNED NOT NULL, views INT(10) UNSIGNED NOT NULL, comments INT(10) UNSIGNED NOT NULL, title VARCHAR(255) NOT NULL, content TEXT NOT NULL ); INSERT INTO article(author_id,category_id,views,comments,title,content) VALUES (1,1,1,1,&#39;1&#39;,&#39;1&#39;), (2,2,2,2,&#39;2&#39;,&#39;2&#39;), (1,1,3,3,&#39;3&#39;,&#39;3&#39;);</pre><div class="contentsignin">로그인 후 복사</div></div><div class="contentsignin">로그인 후 복사</div></div>🎜인덱스 생성<code>ALTER TABLE Staffs ADD INDEX index_staffs_nameAgePos(name,age,pos);
🎜🎜색인 순서name-age-pos
🎜🎜색인 표시show index from Staffs;
🎜🎜🎜🎜왼쪽과 오른쪽 순서를 반대로 하여 실행은 동일🎜🎜주요 문장은 다음 세 문장입니다🎜
- 🎜
설명 select *from Staffs where name='z3'and age=22 and pos='manager ';
🎜🎜 - 🎜< code>설명 *pos='manager' 및 name='z3'and age=22인 직원 중에서 선택;🎜🎜
- 🎜
*나이=22, 위치='관리자', 이름='z3'인 직원 중에서 선택하세요.
🎜🎜🎜🎜🎜🎜위 3가지의 순서를 반대로 하여 조인트 인덱스를 사용합니다. 주된 이유는 MySQL에는 쿼리 최적화 프로그램 설명이 있으므로 SQL 문의 필드 순서는 통합과 결합될 필요가 없습니다. 인덱스에 의해 정의된 필드는 동일한 순서로 되어 있습니다. 이 SQL 문을 수정하는 것이 가장 효율적이며 최종적으로 실제 실행 계획을 생성합니다🎜🎜조인트 인덱스는 순서에 관계없이 사용할 수 있습니다🎜🎜3. 부분 인덱스 순서🎜
3.1 양수
🎜에 있는 경우 주문(팔다리 없음) 동일합니다🎜- 🎜
설명 *이름=‘z3&rsquo인 직원 중에서 선택;;
🎜 🎜 - 🎜
설명 *이름='z3’나이=22인 직원 중에서 선택
🎜🎜< li>🎜설명 *이름='z3’나이인 직원 중에서 선택 =22;
🎜🎜🎜🎜🎜🎜유형은 모두 ref 유형이지만 필드 길이는 약간 변경됩니다. 즉, 정의하는 단어 길이만 변경됩니다🎜
3.2 순서가 잘못되었습니다
🎜 일부 색인이 잘못되었습니다🎜- 🎜첫 번째 색인만 확인하세요
설명 select * from Staffs where name='z3';
🎜🎜< li>🎜중간 색인 건너뛰기explain select *from name='z3' and pos='manager';
🎜 🎜 - 🎜마지막 색인만 확인
explain select *from pos='manager';
🎜🎜🎜🎜🎜🎜양수열을 찾을 수 있습니다🎜🎜팔, 다리가 없어도 일반 인덱스를 따라갈 수 있습니다🎜🎜 중간 인덱스를 생략하더라도 계속 사용할 수 있습니다 index to query🎜🎜근데 마지막 index만 조회하면🎜🎜type이 all type이면 테이블 전체를 직접 조회하게 된다. 순서대로 표시됨,)🎜🎜때때로 유형이 인덱스 유형인 경우가 있는데, 이는 여전히 인덱스를 통해 쿼리할 수 있기 때문입니다.🎜🎜index는 모든 인덱스 트리를 스캔하는 반면 all은 전체 테이블에서 전체 디스크의 데이터를 스캔합니다. 🎜🎜4. index🎜🎜유사한 퍼지 인덱스는 like 문을 사용합니다🎜🎜그래서 다음 세 문은🎜🎜가장 왼쪽 접두사와 결합하면 범위 또는 인덱스 유형이 인덱싱에 사용됩니다🎜
- 🎜
설명 *from 이름이 '3%'인 직원에서 선택;
가장 왼쪽 접두사 색인, 유형은 색인 또는 범위입니다🎜🎜 - 🎜
설명 *from 직원에서 이름 선택 like '%3%';
유형은 모두, 전체 테이블 쿼리🎜🎜 - 🎜
설명 *이름이 '%3%';
인 직원 중에서 선택, 유형은 모두, 전체 테이블 쿼리🎜🎜🎜🎜🎜🎜🎜5. 범위 인덱스🎜🎜여러 필드를 쿼리할 때 중간에 범위가 있는 경우 인덱스를 삭제하고 중간 인덱스를 제거하는 것이 좋습니다🎜 🎜구체적인 아이디어는 다음과 같습니다. 🎜建立一张单表
CREATE TABLE IF NOT EXISTS article( id INT(10) UNSIGNED NOT NULL PRIMARY KEY AUTO_INCREMENT, author_id INT(10) UNSIGNED NOT NULL, category_id INT(10) UNSIGNED NOT NULL, views INT(10) UNSIGNED NOT NULL, comments INT(10) UNSIGNED NOT NULL, title VARCHAR(255) NOT NULL, content TEXT NOT NULL ); INSERT INTO article(author_id,category_id,views,comments,title,content) VALUES (1,1,1,1,'1','1'), (2,2,2,2,'2','2'), (1,1,3,3,'3','3');
로그인 후 복사로그인 후 복사经过如下查询:
explain SELECT id, author_id FROM article WHERE category_id = 1 AND comments > 1 ORDER BY views DESC LIMIT 1;
로그인 후 복사发现其上面的单表查询,不是索引的话,他是进行了全表查询,而且在extra还出现了Using filesort等问题
所以思路可以有建立其复合索引
具体建立复合索引有两种方式:
create index idx_article_ccv on article(category_id,comments,views);
ALTER TABLE 'article' ADD INDEX idx_article_ccv ( 'category_id , 'comments', 'views' );
但这只是去除了它的范围,如果要去除Using filesort问题的话,还要将其中间的条件范围改为等于号才可满足
发现其思路不行,所以删除其索引
DROP INDEX idx_article_ccv ON article;
主要的原因是:
这是因为按照BTree索引的工作原理,先排序category_id,如果遇到相同的category_id则再排序comments,如果遇到相同的comments 则再排序views。
当comments字段在联合索引里处于中间位置时,因comments > 1条件是一个范围值(所谓range),MySQL无法利用索引再对后面的views部分进行检索,即range类型查询字段后面的索引无效。
所以建立复合索引是对的
但是其思路要避开中间那个范围的索引进去
只加入另外两个索引即可
create index idx_article_cv on article(category_id, views);
위 내용은 MySQL 인덱스의 가장 왼쪽 접두사 원칙은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!
- 🎜
- 🎜첫 번째 색인만 확인하세요
- 🎜
- 🎜

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템으로, 주로 데이터를 신속하고 안정적으로 저장하고 검색하는 데 사용됩니다. 작업 원칙에는 클라이언트 요청, 쿼리 해상도, 쿼리 실행 및 반환 결과가 포함됩니다. 사용의 예로는 테이블 작성, 데이터 삽입 및 쿼리 및 조인 작업과 같은 고급 기능이 포함됩니다. 일반적인 오류에는 SQL 구문, 데이터 유형 및 권한이 포함되며 최적화 제안에는 인덱스 사용, 최적화 된 쿼리 및 테이블 분할이 포함됩니다.

데이터베이스 및 프로그래밍에서 MySQL의 위치는 매우 중요합니다. 다양한 응용 프로그램 시나리오에서 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) MySQL은 웹, 모바일 및 엔터프라이즈 레벨 시스템을 지원하는 효율적인 데이터 저장, 조직 및 검색 기능을 제공합니다. 2) 클라이언트 서버 아키텍처를 사용하고 여러 스토리지 엔진 및 인덱스 최적화를 지원합니다. 3) 기본 사용에는 테이블 작성 및 데이터 삽입이 포함되며 고급 사용에는 다중 테이블 조인 및 복잡한 쿼리가 포함됩니다. 4) SQL 구문 오류 및 성능 문제와 같은 자주 묻는 질문은 설명 명령 및 느린 쿼리 로그를 통해 디버깅 할 수 있습니다. 5) 성능 최적화 방법에는 인덱스의 합리적인 사용, 최적화 된 쿼리 및 캐시 사용이 포함됩니다. 모범 사례에는 거래 사용 및 준비된 체계가 포함됩니다

MySQL은 성능, 신뢰성, 사용 편의성 및 커뮤니티 지원을 위해 선택됩니다. 1.MYSQL은 효율적인 데이터 저장 및 검색 기능을 제공하여 여러 데이터 유형 및 고급 쿼리 작업을 지원합니다. 2. 고객-서버 아키텍처 및 다중 스토리지 엔진을 채택하여 트랜잭션 및 쿼리 최적화를 지원합니다. 3. 사용하기 쉽고 다양한 운영 체제 및 프로그래밍 언어를 지원합니다. 4. 강력한 지역 사회 지원을 받고 풍부한 자원과 솔루션을 제공합니다.

Apache는 데이터베이스에 연결하여 다음 단계가 필요합니다. 데이터베이스 드라이버 설치. 연결 풀을 만들려면 Web.xml 파일을 구성하십시오. JDBC 데이터 소스를 작성하고 연결 설정을 지정하십시오. JDBC API를 사용하여 Connections, 명세서 작성, 매개 변수 바인딩, 쿼리 또는 업데이트 실행 및 처리를 포함하여 Java 코드의 데이터베이스에 액세스하십시오.

Docker에서 MySQL을 시작하는 프로세스는 다음 단계로 구성됩니다. MySQL 이미지를 가져와 컨테이너를 작성하고 시작하고 루트 사용자 암호를 설정하고 포트 확인 연결을 매핑하고 데이터베이스를 작성하고 사용자는 데이터베이스에 모든 권한을 부여합니다.

웹 응용 프로그램에서 MySQL의 주요 역할은 데이터를 저장하고 관리하는 것입니다. 1. MySQL은 사용자 정보, 제품 카탈로그, 트랜잭션 레코드 및 기타 데이터를 효율적으로 처리합니다. 2. SQL 쿼리를 통해 개발자는 데이터베이스에서 정보를 추출하여 동적 컨텐츠를 생성 할 수 있습니다. 3.mysql은 클라이언트-서버 모델을 기반으로 작동하여 허용 가능한 쿼리 속도를 보장합니다.

Laravel은 웹 응용 프로그램을 쉽게 구축하기위한 PHP 프레임 워크입니다. 설치 : Composer를 사용하여 전 세계적으로 Laravel CLI를 설치하고 프로젝트 디렉토리에서 응용 프로그램을 작성하는 등 다양한 기능을 제공합니다. 라우팅 : Routes/Web.php에서 URL과 핸들러 간의 관계를 정의하십시오. 보기 : 리소스/뷰에서보기를 작성하여 응용 프로그램의 인터페이스를 렌더링합니다. 데이터베이스 통합 : MySQL과 같은 데이터베이스와 상자 외 통합을 제공하고 마이그레이션을 사용하여 테이블을 작성하고 수정합니다. 모델 및 컨트롤러 : 모델은 데이터베이스 엔티티를 나타내고 컨트롤러는 HTTP 요청을 처리합니다.

MySQL을 우아하게 설치하는 열쇠는 공식 MySQL 저장소를 추가하는 것입니다. 특정 단계는 다음과 같습니다. 피싱 공격을 방지하기 위해 MySQL 공식 GPG 키를 다운로드하십시오. MySQL 리포지토리 파일 추가 : rpm -uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm yum repository cache : yum 업데이트 설치 mysql : yum 설치 mysql-server startup startup mysql 서비스 : systemctl start mysqlctl start mysqlctl.
