데이터 베이스 MySQL 튜토리얼 SQL 문 최적화 전략 소개

SQL 문 최적화 전략 소개

Jan 28, 2020 pm 10:05 PM
SQL 문 소개하다 최적화 전략

SQL 문 최적화 전략 소개

1. 전체 테이블 스캔을 피하세요

쿼리를 최적화하려면 먼저 where 및 order by와 관련된 열에 대한 인덱스 생성을 고려하세요.

2. null 값 판단을 피하세요 ​​

where 절의 필드에 대해 null 값 판단을 피하세요. 그렇지 않으면 엔진이 인덱스 사용을 포기하고 다음과 같이 전체 테이블 스캔을 수행합니다.

는 num에 설정할 수 있습니다. 기본값은 0입니다. 테이블의 num 열에 null 값이 없는지 확인한 후 다음과 같이 쿼리합니다.

select id from t where num is null
로그인 후 복사

(무료 학습 비디오 튜토리얼 권장: mysql 비디오 튜토리얼)

3. 불평등한 값 판단을 피하세요

where 절에 != 또는 <> 연산자를 사용하지 마세요. 그렇지 않으면 엔진이 인덱스 사용을 포기하고 전체 테이블 스캔을 수행합니다.

4. 또는 논리 사용을 피하세요.

where 절에서 조건을 연결하는 것을 피해야 합니다. 그렇지 않으면 엔진이 인덱스 사용을 포기하고 전체 테이블 스캔을 수행하게 됩니다. as:

select id from t where num=0
로그인 후 복사

다음과 같이 쿼리할 수 있습니다.

select id from t where num=10 or num=20
로그인 후 복사

5. 논리에 in과 not을 주의해서 사용하세요.

in과 not in도 주의해서 사용해야 합니다. 그렇지 않으면 전체 테이블 스캔으로 이어질 것입니다. as:

select id from t where num=10
union all
select id from t where num=20
로그인 후 복사

이때 외부 쿼리는 전체 테이블을 스캔하므로 인덱스를 사용하지 마십시오. 다음과 같이 수정할 수 있습니다.

select id from t1 where num in(select id from t2 where id > 10)
로그인 후 복사

이때 인덱스를 사용하므로 쿼리 효율성을 크게 향상시킬 수 있습니다.

6. 퍼지 쿼리에 주의하세요

다음 쿼리도 전체 테이블 스캔을 발생시킵니다.

select id from t1,(select id from t1 where id > 10)t2 where t1.id = t2.id
로그인 후 복사

퍼지 쿼리 필수 조건인 경우 'abc%'와 같은 이름이 있는 t에서 ID를 선택하면 됩니다. 퍼지 쿼리를 구현하려면 이 시점에서 인덱스가 사용됩니다. 헤더 매칭이 필요한 로직이라면 전체 텍스트 검색 엔진(Elastic Search, Lucene, Solr 등)을 사용하는 것이 좋습니다.

7. 쿼리 조건에서 필드 계산을 피하세요

where 절의 필드에 대한 표현식 작업을 피해야 합니다. 이렇게 하면 엔진이 인덱스 사용을 포기하고 전체 테이블 스캔을 수행하게 됩니다. 예:

select id from t where name like &#39;%abc%&#39;
로그인 후 복사

는 다음으로 변경되어야 합니다.

select id from t where num/2=100
로그인 후 복사

8. 쿼리 조건의 필드에 기능적 작업을 수행하지 마십시오.

where 절의 필드에 기능적 작업을 수행하지 마십시오. 전체 테이블 스캔을 사용하지 마십시오. 예:

select id from t where num=100*2
로그인 후 복사

는 다음과 같이 변경되어야 합니다.

select id from t where substring(name,1,3)=&#39;abc&#39;--name 以abc 开头的id
로그인 후 복사

9. WHERE 절의 "=" 왼쪽에 주의하십시오.

왼쪽에서는 함수, 산술 연산 또는 기타 표현식 연산을 수행하지 마십시오. where 절에 "="를 사용하지 않으면 시스템이 인덱스를 올바르게 사용하지 못할 수 있습니다.

10. 결합 인덱스 사용

인덱스 필드를 조건으로 사용할 때 인덱스가 복합 인덱스인 경우 시스템이 인덱스를 사용하도록 하려면 인덱스의 첫 번째 필드를 조건으로 사용해야 합니다. 그렇지 않으면 시스템은 인덱스가 사용되지 않으며 필드 순서는 가능할 때마다 인덱스 순서와 일치해야 합니다.

11. 불쾌한 쿼리를 정의하지 마세요.

의미 없는 쿼리를 작성하지 마세요. 예를 들어 빈 테이블 구조를 생성해야 하는 경우:

select id from t where name like &#39;abc%&#39;
로그인 후 복사

이 유형의 코드는 결과 집합을 반환하지 않지만 시스템 리소스를 소비합니다.

select col1,col2 into #t from t where 1=0
로그인 후 복사

12.exists

대부분의 경우 in 대신 presents를 사용하는 것이 좋은 선택입니다.

create table #t(...)
로그인 후 복사

다음 문으로 바꾸세요.

select num from a where num in(select num from b)
로그인 후 복사

13. 인덱스가 유효하지 않을 수도 있습니다

并不是所有索引对查询都有效,SQL 是根据表中数据来进行查询优化的,当索引列有大量数据重复时,SQL 查询可能不会去利用索引,如一表中有字段sex,male、female 几乎各一半,那么即使在sex 上建了索引也对查询效率起不了作用。

14、表格字段类型选择

尽量使用数字型字段,若只含数值信息的字段尽量不要设计为字符型,这会降低查询和连接的性能,并会增加存储开销。

这是因为引擎在处理查询和连接时会逐个比较字符串中每一个字符,而对于数字型而言只需要比较一次就够了。尽可能的使用varchar 代替char ,因为首先可变长度字段存储空间小,可以节省存储空间,其次对于查询来说,在一个相对较小的字段内搜索效率显然要高些。

15、查询语法中的字段

任何地方都不要使用select * from t ,用具体的字段列表代替“*”,不要返回用不到的任何字段。

16、索引无关优化

不使用*、尽量不使用union,union all 等关键字、尽量不使用or 关键字、尽量使用等值判断。表连接建议不超过5 个。如果超过5 个,则考虑表格的设计。(互联网应用中)表连接方式使用外联优于内联。外连接有基础数据存在。

如:A left join B,基础数据是A。A inner join B,没有基础数据的,先使用笛卡尔积完成全连接,在根据连接条件得到内连接结果集。

大数据量级的表格做分页查询时,如果页码数量过大,则使用子查询配合完成分页逻辑。

Select * from table limit 1000000, 10
Select * from table where id in (select pk from table limit100000, 10)
로그인 후 복사

相关文章教程推荐:mysql教程

위 내용은 SQL 문 최적화 전략 소개의 상세 내용입니다. 자세한 내용은 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 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Windows 7에 MySQL을 설치할 수 있습니까? Windows 7에 MySQL을 설치할 수 있습니까? Apr 08, 2025 pm 03:21 PM

예, MySQL은 Windows 7에 설치 될 수 있으며 Microsoft는 Windows 7 지원을 중단했지만 MySQL은 여전히 ​​호환됩니다. 그러나 설치 프로세스 중에 다음 지점이 표시되어야합니다. Windows 용 MySQL 설치 프로그램을 다운로드하십시오. MySQL의 적절한 버전 (커뮤니티 또는 기업)을 선택하십시오. 설치 프로세스 중에 적절한 설치 디렉토리 및 문자를 선택하십시오. 루트 사용자 비밀번호를 설정하고 올바르게 유지하십시오. 테스트를 위해 데이터베이스에 연결하십시오. Windows 7의 호환성 및 보안 문제에 주목하고 지원되는 운영 체제로 업그레이드하는 것이 좋습니다.

SQL 문을 사용하여 SQL Server로 테이블을 만드는 방법 SQL 문을 사용하여 SQL Server로 테이블을 만드는 방법 Apr 09, 2025 pm 03:48 PM

SQL Server에서 SQL 문을 사용하여 테이블을 만드는 방법 : SQL Server Management Studio를 열고 데이터베이스 서버에 연결하십시오. 테이블을 만들려면 데이터베이스를 선택하십시오. 테이블 이름, 열 이름, 데이터 유형 및 제약 조건을 지정하려면 테이블 작성 문을 입력하십시오. 실행 버튼을 클릭하여 테이블을 만듭니다.

SQL 주입을 판단하는 방법 SQL 주입을 판단하는 방법 Apr 09, 2025 pm 04:18 PM

SQL 주입을 판단하는 방법에는 의심스러운 입력 감지, 원래 SQL 문보기, 탐지 도구 사용, 데이터베이스 로그보기 및 침투 테스트 수행이 포함됩니다. 주입이 감지 된 후에는 패치 취약점에 대한 조치를 취하고 패치를 확인하고 정기적으로 모니터링하며 개발자 인식을 향상시킵니다.

SQL 문을 확인하는 방법 SQL 문을 확인하는 방법 Apr 09, 2025 pm 04:36 PM

SQL 문을 확인하는 방법은 다음과 같습니다. 구문 확인 : SQL 편집기 또는 IDE를 사용하십시오. 논리 점검 : 테이블 이름, 열 이름, 조건 및 데이터 유형을 확인하십시오. 성능 점검 : 설명 또는 분석을 사용하여 색인을 확인하고 쿼리를 최적화하십시오. 기타 점검 : 변수, 권한 및 테스트 쿼리를 확인하십시오.

MySQL은 잠금 테이블을 최적화합니까? MySQL은 잠금 테이블을 최적화합니까? Apr 08, 2025 pm 01:51 PM

MySQL은 공유 잠금 장치 및 독점 잠금 장치를 사용하여 동시성을 관리하여 테이블 잠금, 행 잠금 및 페이지 잠금의 세 가지 잠금 유형을 제공합니다. 행 잠금은 동시성을 향상시키고 For Update 문을 사용하여 독점 잠금을 행에 추가 할 수 있습니다. 비관적 잠금은 충돌을 가정하고 낙관적 잠금은 버전 번호를 통해 데이터를 판단합니다. 일반적인 잠금 테이블 문제는 느린 쿼리로 나타납니다. Show ProcessList 명령을 사용하여 잠금 장치가 보유한 쿼리를보십시오. 최적화 측정에는 적절한 인덱스 선택, 트랜잭션 범위 감소, 배치 작업 및 SQL 문을 최적화하는 것이 포함됩니다.

MySQL은 지불해야합니다 MySQL은 지불해야합니다 Apr 08, 2025 pm 05:36 PM

MySQL에는 무료 커뮤니티 버전과 유료 엔터프라이즈 버전이 있습니다. 커뮤니티 버전은 무료로 사용 및 수정할 수 있지만 지원은 제한되어 있으며 안정성이 낮은 응용 프로그램에 적합하며 기술 기능이 강합니다. Enterprise Edition은 안정적이고 신뢰할 수있는 고성능 데이터베이스가 필요하고 지원 비용을 기꺼이 지불하는 응용 프로그램에 대한 포괄적 인 상업적 지원을 제공합니다. 버전을 선택할 때 고려 된 요소에는 응용 프로그램 중요도, 예산 책정 및 기술 기술이 포함됩니다. 완벽한 옵션은없고 가장 적합한 옵션 만 있으므로 특정 상황에 따라 신중하게 선택해야합니다.

SQL 문에서 3 개의 테이블을 연결하는 방법에 대한 자습서를 작성하는 방법 SQL 문에서 3 개의 테이블을 연결하는 방법에 대한 자습서를 작성하는 방법 Apr 09, 2025 pm 02:03 PM

이 기사에서는 SQL 문을 사용하여 3 개의 테이블에 가입하는 것에 대한 자세한 자습서를 소개합니다. 독자는 다른 테이블의 데이터를 효과적으로 상관시키는 방법을 배우도록 독자를 안내합니다. 예제 및 세부 구문 설명을 통해이 기사를 사용하면 SQL에서 테이블의 결합 기술을 마스터하여 데이터베이스에서 관련 정보를 효율적으로 검색 할 수 있습니다.

SQL이 행을 삭제 한 후 데이터를 복구하는 방법 SQL이 행을 삭제 한 후 데이터를 복구하는 방법 Apr 09, 2025 pm 12:21 PM

백업 또는 트랜잭션 롤백 메커니즘이없는 한 데이터베이스에서 직접 삭제 된 행 복구는 일반적으로 불가능합니다. 키 포인트 : 거래 롤백 : 트랜잭션이 데이터를 복구하기 전에 롤백을 실행합니다. 백업 : 데이터베이스의 일반 백업을 사용하여 데이터를 신속하게 복원 할 수 있습니다. 데이터베이스 스냅 샷 : 데이터베이스의 읽기 전용 사본을 작성하고 데이터를 실수로 삭제 한 후 데이터를 복원 할 수 있습니다. 주의해서 삭제 명령문을 사용하십시오. 실수로 데이터를 삭제하지 않도록 조건을주의 깊게 점검하십시오. WHERE 절을 사용하십시오 : 삭제할 데이터를 명시 적으로 지정하십시오. 테스트 환경 사용 : 삭제 작업을 수행하기 전에 테스트하십시오.

See all articles