데이터 베이스 MySQL 튜토리얼 MySQL 인덱스 오류를 일으키는 상황

MySQL 인덱스 오류를 일으키는 상황

Feb 18, 2024 pm 06:02 PM
SQL 문 MySQL 인덱스 잘못된 인덱스 선택

MySQL 인덱스 오류를 일으키는 상황

MySQL 인덱스 오류의 여러 상황 및 코드 예

소개:
MySQL 데이터베이스에서 인덱스는 쿼리 성능을 향상시키는 중요한 요소 중 하나입니다. 그러나 때로는 인덱스가 예상한 역할을 수행하지 않고 쿼리 성능이 향상되지 않으며 쿼리 속도가 느려지는 경우도 있습니다. 그 이유는 아마도 인덱스가 유효하지 않기 때문일 것입니다. 이 기사에서는 MySQL 인덱스 오류를 일으키는 몇 가지 일반적인 상황을 소개하고 해당 코드 예제를 제공합니다.

1. 함수 또는 표현식을 사용하여 인덱스 열에 대한 작업 수행
쿼리 문에서 인덱스 열에 대해 함수 호출 또는 표현식 작업을 수행하면 인덱스가 무효화되고 MySQL은 빠른 쿼리에 인덱스를 사용할 수 없게 됩니다. 예는 다음과 같습니다.

-- 创建表
CREATE TABLE `user_address` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `user_id` int(11) DEFAULT NULL,
  `address` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `idx_user_id` (`user_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- 查询示例,索引失效
SELECT * FROM `user_address` WHERE YEAR(`address`) = 2022;
로그인 후 복사

위 코드에서 address 열에 YEAR 함수를 사용했기 때문에 MySQL은 인덱스 idx_user_id<를 사용할 수 없습니다. /code> 로 인해 인덱스 오류가 발생하고 쿼리 효율성이 저하됩니다. <code>address列使用了YEAR函数进行运算,使得MySQL无法利用索引idx_user_id,导致索引失效,查询效率下降。

二、在索引列上使用了函数
在索引列上使用函数也会导致索引失效,比如下面的示例:

-- 查询示例,索引失效
SELECT * FROM `user_address` WHERE LEFT(`address`, 5) = 'China';
로그인 후 복사

上述代码中,由于对address列使用了LEFT函数,同样使得MySQL无法利用索引idx_user_id,导致索引失效。

三、使用LIKE操作符模糊查询
在使用LIKE操作符进行模糊查询时,如果不是以%通配符开头,将导致索引失效。示例如下:

-- 查询示例,索引失效
SELECT * FROM `user_address` WHERE `address` LIKE 'Shanghai%';
로그인 후 복사

上述代码中,由于LIKE操作符不是以%通配符开头,MySQL无法利用索引idx_user_id,查询性能下降。

四、查询条件中使用OR关键字
在查询条件中使用OR关键字,如果每个OR子句中的列没有索引,将导致索引失效。示例如下:

-- 查询示例,索引失效
SELECT * FROM `user_address` WHERE `user_id` = 1 OR `address` = 'Shanghai';
로그인 후 복사

上述代码中,由于user_idaddress

2. 인덱스 열에 함수 사용

다음 예와 같이 인덱스 열에 함수를 사용하면 인덱스 오류가 발생합니다.
rrreee

위 코드에서는 address 열 사용으로 인해 code>LEFT 함수는 또한 MySQL이 인덱스 idx_user_id를 사용하는 것을 방지하여 인덱스 실패를 유발합니다.


3. 퍼지 쿼리에 LIKE 연산자를 사용하세요

퍼지 쿼리에 LIKE 연산자를 사용할 때 % 와일드카드 문자로 시작하지 않으면 인덱스가 실패합니다. 예를 들면 다음과 같습니다.

rrreee

위 코드에서 LIKE 연산자는 % 와일드카드 문자로 시작하지 않기 때문에 MySQL은 인덱스 idx_user_id를 사용할 수 없으며 쿼리 성능이 저하됩니다. 🎜🎜4. 쿼리 조건에 OR 키워드를 사용하세요. 🎜 쿼리 조건에 OR 키워드를 사용하세요. 각 OR 절의 열이 인덱스되지 않으면 인덱스가 유효하지 않습니다. 예를 들면 다음과 같습니다. 🎜rrreee🎜위 코드에서 user_idaddress 열은 각각 고유한 인덱스를 갖고 있으므로 OR의 두 가지 조건에서 사용됩니다. 각각의 키워드 연결. 인덱스가 다르면 인덱스 오류가 발생합니다. 🎜🎜요약: 🎜MySQL 데이터베이스를 사용할 때는 인덱스 오류로 이어지는 위의 시나리오를 피해야 합니다. SQL 문을 작성할 때 인덱스 열에 함수나 표현식 작업을 수행하는 것을 피하고, 적절한 연산자와 연결을 사용하여 쿼리 조건을 구성하여 인덱스가 쿼리 작업에 효과적으로 사용될 수 있도록 하고 쿼리 성능을 향상시켜야 합니다. 🎜🎜참고자료: 🎜MySQL 공식 문서 (https://dev.mysql.com/doc/)🎜🎜(참고: 위 예의 테이블 구조와 쿼리문은 예시용일 뿐입니다. 실제 상황은 상황에 따라 다를 수 있습니다. 데이터베이스 버전 및 인덱스 설정 등)🎜

위 내용은 MySQL 인덱스 오류를 일으키는 상황의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Excel에서 iif 함수를 사용하는 방법 Excel에서 iif 함수를 사용하는 방법 Mar 20, 2024 pm 06:10 PM

대부분의 사용자는 테이블 데이터를 처리하기 위해 Excel을 사용합니다. 실제로 Excel에도 VBA 프로그램이 있습니다. 전문가를 제외하고는 이 기능을 사용하는 사용자가 많지 않습니다. iif 함수는 실제로 VBA와 유사합니다. iif 함수의 사용법을 소개하겠습니다. SQL 문에는 iif 함수가 있고 Excel에는 VBA 코드가 있습니다. iif 함수는 Excel 워크시트의 IF 함수와 유사하며 참과 거짓 값을 판단하고 논리적으로 계산된 참과 거짓 값을 기반으로 서로 다른 결과를 반환합니다. IF 함수 사용법은 (조건, 예, 아니오)입니다. VBA의 IF문과 IIF 함수 전자의 IF문은 조건에 따라 다른 명령문을 실행할 수 있는 제어문인 반면 후자는

Oracle 데이터베이스 로그를 쿼리하는 방법 Oracle 데이터베이스 로그를 쿼리하는 방법 Apr 07, 2024 pm 04:51 PM

Oracle 데이터베이스 로그 정보는 다음 방법으로 쿼리할 수 있습니다. v$log 보기에서 쿼리하려면 LogMiner 도구를 사용하고, ALTER SYSTEM 명령을 사용하여 현재 로그 파일의 상태를 확인합니다. 특정 이벤트에 대한 정보를 보기 위한 TRACE 명령, 작업 사용 시스템 도구는 로그 파일의 끝을 확인합니다.

sql 문을 사용하여 mysql 데이터베이스의 저장 구조를 쿼리하는 방법 sql 문을 사용하여 mysql 데이터베이스의 저장 구조를 쿼리하는 방법 Apr 14, 2024 pm 07:45 PM

MySQL 데이터베이스 스토리지 구조를 쿼리하려면 다음 SQL 문을 사용할 수 있습니다. SHOW CREATE TABLE table_name 이 문은 열 이름, 데이터 유형, 제약 조건 및 일반 속성을 포함하여 테이블의 열 정의 및 테이블 옵션 정보를 반환합니다. 스토리지 엔진, 문자 세트 등 테이블의 구성 요소입니다.

navicat에서 쿼리된 데이터를 내보내는 방법 navicat에서 쿼리된 데이터를 내보내는 방법 Apr 24, 2024 am 04:15 AM

Navicat에서 쿼리 결과 내보내기: 쿼리를 실행합니다. 쿼리 결과를 마우스 오른쪽 버튼으로 클릭하고 데이터 내보내기를 선택합니다. 필요에 따라 내보내기 형식을 선택하십시오. CSV: 필드 구분 기호는 쉼표입니다. Excel: Excel 형식을 사용하여 테이블 헤더를 포함합니다. SQL 스크립트: 쿼리 결과를 다시 생성하는 데 사용되는 SQL 문이 포함되어 있습니다. 내보내기 옵션(예: 인코딩, 줄 바꿈)을 선택합니다. 내보내기 위치와 파일 이름을 선택합니다. 내보내기를 시작하려면 "내보내기"를 클릭하세요.

mysql 데이터베이스 초기화 실패를 해결하는 방법 mysql 데이터베이스 초기화 실패를 해결하는 방법 Apr 14, 2024 pm 07:12 PM

MySQL 데이터베이스 초기화 실패 문제를 해결하려면 다음 단계를 따르십시오. 권한을 확인하고 적절한 권한이 있는 사용자를 사용하고 있는지 확인하십시오. 데이터베이스가 이미 존재하는 경우 삭제하거나 다른 이름을 선택하십시오. 테이블이 이미 존재하는 경우 삭제하거나 다른 이름을 선택하십시오. 구문 오류가 있는지 SQL 문을 확인하세요. MySQL 서버가 실행 중이고 연결 가능한지 확인합니다. 올바른 포트 번호를 사용하고 있는지 확인하십시오. 다른 오류에 대한 자세한 내용은 MySQL 로그 파일이나 오류 코드 찾기를 확인하세요.

mysql 데이터베이스에서 sql 문을 실행하는 방법 mysql 데이터베이스에서 sql 문을 실행하는 방법 Apr 14, 2024 pm 07:48 PM

MySQL SQL 문은 다음을 통해 실행할 수 있습니다. MySQL CLI(명령줄 인터페이스) 사용: 데이터베이스에 로그인하고 SQL 문을 입력합니다. MySQL Workbench 사용: 애플리케이션을 시작하고, 데이터베이스에 연결하고, 명령문을 실행합니다. 프로그래밍 언어 사용: MySQL 연결 라이브러리를 가져오고, 데이터베이스 연결을 만들고, 명령문을 실행합니다. SQLite용 DB 브라우저와 같은 다른 도구를 사용하세요. 애플리케이션을 다운로드 및 설치하고, 데이터베이스 파일을 열고, 명령문을 실행하세요.

MySQL 트랜잭션 처리: 자동 제출과 수동 제출의 차이점 MySQL 트랜잭션 처리: 자동 제출과 수동 제출의 차이점 Mar 16, 2024 am 11:33 AM

MySQL 트랜잭션 처리: 자동 제출과 수동 제출의 차이점 MySQL 데이터베이스에서 트랜잭션은 모든 실행이 성공하거나 모든 실행이 실패하여 데이터의 일관성과 무결성을 보장합니다. MySQL에서는 트랜잭션을 자동 제출과 수동 제출로 나눌 수 있는데, 차이점은 트랜잭션 제출 시기와 트랜잭션에 대한 제어 범위에 있습니다. 다음에서는 자동 제출과 수동 제출의 차이점을 자세히 소개하고 설명할 특정 코드 예제를 제공합니다. 1. 표시되지 않는 경우 MySQL에서 자동으로 제출

MySQL과 PL/SQL의 유사점과 차이점 비교 MySQL과 PL/SQL의 유사점과 차이점 비교 Mar 16, 2024 am 11:15 AM

MySQL과 PL/SQL은 각각 관계형 데이터베이스와 절차적 언어의 특성을 나타내는 서로 다른 두 가지 데이터베이스 관리 시스템입니다. 이 기사에서는 구체적인 코드 예제를 통해 MySQL과 PL/SQL 간의 유사점과 차이점을 비교합니다. MySQL은 SQL(구조적 쿼리 언어)을 사용하여 데이터베이스를 관리하고 운영하는 인기 있는 관계형 데이터베이스 관리 시스템입니다. PL/SQL은 Oracle 데이터베이스 고유의 절차적 언어로 저장 프로시저, 트리거, 함수 등의 데이터베이스 개체를 작성하는 데 사용됩니다. 같은

See all articles