어떤 인덱스가 사용되는지 확인하려면 설명에서 key_len을 확인하세요.
where 필드의 조건에 여러 개의 인덱스 값이 있으므로 어떤 것을 사용해야 합니까?
권장 사항: "# 🎜🎜#mysql 비디오 튜토리얼"
설명을 사용하여 볼 수 있으며 key_len 필드를 볼 수 있습니다# 🎜🎜#For 예를 들어, 다음 sql
explain select * from ent_calendar_diary where email='xxxx' and diary_id=1784; +----+-------------+--------------------+------------+-------+-------------------------+---------+---------+-------+------+----------+-------+ | id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra | +----+-------------+--------------------+------------+-------+-------------------------+---------+---------+-------+------+----------+-------+ | 1 | SIMPLE | ent_calendar_diary | NULL | const | PRIMARY,idx_email_stime | PRIMARY | 4 | const | 1 | 100.00 | NULL | +----+-------------+--------------------+------------+-------+-------------------------+---------+---------+-------+------+----------+-------+
possible_keys에는 두 개의 인덱스 필드가 있지만 key_len은 4바이트입니다. # 🎜🎜#
# 🎜🎜#참고, key_len은 조건부 필터링을 위해 WHERE에서 선택한 인덱스 열만 나타내며 ORDER BY/GROUP BYint 유형을 포함하지 않으며 null이 아닌 경우는 4입니다. 바이트이므로 위의 SQL은 사용된 기본 키 인덱스입니다.
explain select * from ent_calendar_diary where email='xxxx'; +----+-------------+--------------------+------------+------+-----------------+-----------------+---------+-------+------+----------+-------+ | id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra | +----+-------------+--------------------+------------+------+-----------------+-----------------+---------+-------+------+----------+-------+ | 1 | SIMPLE | ent_calendar_diary | NULL | ref | idx_email_stime | idx_email_stime | 767 | const | 111 | 100.00 | NULL | +----+-------------+--------------------+------------+------+-----------------+-----------------+---------+-------+------+----------+-------+
this 767바이트입니다. varchar(255)는 null 255가 아닙니다. * 3+2가 정확히 일치하므로 사용된 이메일의 일반 색인입니다
CREATE TABLE `ent_calendar_diary` ( `diary_id` int(10) unsigned NOT NULL AUTO_INCREMENT, `email` varchar(255) NOT NULL, `title` varchar(100) NOT NULL, `summary` varchar(500) NOT NULL DEFAULT '', `stime` bigint(11) NOT NULL DEFAULT '0', `ctime` int(10) unsigned NOT NULL DEFAULT '0', PRIMARY KEY (`diary_id`), KEY `idx_email_stime` (`email`,`stime`) ) ENGINE=InnoDB AUTO_INCREMENT=1809 DEFAULT CHARSET=utf8
위 내용은 어떤 인덱스가 사용되는지 확인하려면 설명에서 key_len을 확인하세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!