찾다
백엔드 개발PHP 튜토리얼Selllimit Limit 매개변수를 사용하여 MySQL 쿼리를 최적화하는 방법

며칠 전 외국인이 작성한 프로그램을 보았는데 MySQL 쿼리에 Limit 키워드를 많이 사용하는 것 같았습니다. 제가 보기엔 MySQL 데이터베이스에서 Limit 키워드를 더 많이 사용하는 것 같아서 매우 흥미로웠습니다. 프로그래머는 이를 사용하여 쿼리 페이징을 수행합니다. (물론 이는 좋은 쿼리 최적화이기도 합니다.) 다음은 페이징 쿼리가 필요하다고 가정합니다. Oracle은 일반적으로 이를 구현하기 위해 다음 SQL 문장을 사용합니다. >( SELECT a1.*, rownum rownum_
FROM testtable a1
WHERE rownum > 20)
WHERE rownum_ 이 명령문은 테이블의 레코드 20~1000개를 테스트 테이블에 쿼리할 수 있습니다. 그리고 중첩된 쿼리가 필요합니다. 이는 그다지 효율적이지 않습니다. MySQL의 구현을 살펴보겠습니다.
SELECT * FROM testtable a1limit 20,980;
이것은 테스트 테이블 레코드에서 (20 + 980 =)로 21을 반환합니다. 1000개의 레코드.
구현 구문은 참으로 간단하지만, 여기서 두 SQL 문의 효율성에 대해 이야기하고 싶다면 MySQL에서 Limit 옵션을 해석하는 방법이 다양하고 속도 차이가 있기 때문에 비교하기가 어렵습니다. 규모가 크므로 이 진술의 단순성을 토대로 누가 더 효율적인지 말할 수 없습니다.
그래도 프로그래머 입장에서는 간단하면 유지비가 저렴하니까 좋죠, 하하.
이 Limit의 구문에 대해 이야기해 보겠습니다.
SELECT ……. --Select 문의 다른 매개변수
[LIMIT {[offset,] row_count | row_count OFFSET offset}]
여기서 오프셋은 오프셋 Shift(이 오프셋의 시작 주소는 1이 아닌 0이므로 실수하기 쉽습니다.) 이름에서 알 수 있듯이 시작점에서 떨어진 위치이며 행 개수도 매우 간단합니다. 반환되는 레코드 수에 대한 제한.
예: SELECT * FROM testtable alimit 10,20 where ....
이렇게 하면 10개 행 이후에 where 조건을 충족하는 20개의 레코드가 반환됩니다(10개 행 자체 포함).
그런 다음 제약 조건이 없으면 10~29행의 레코드가 반환됩니다.
그렇다면 이것이 전체 테이블 스캔을 피하는 것과 어떤 관련이 있습니까? 다음은 Limit 매개변수 최적화 스캔에 대한 MySQL 매뉴얼의 설명입니다.
어떤 경우에는 HAVING을 사용하는 대신 LIMIT 옵션을 사용할 때 MySQL이 쿼리를 다르게 처리합니다.
l LIMIT를 사용하여 행의 하위 집합만 선택하는 경우 MySQL은 일반적으로 전체 테이블 스캔을 수행하지만 경우에 따라 인덱스(ipart 관련)를 사용합니다.
l ORDER BY와 함께 LIMIT n을 동시에 사용하면 MySQL이 기준에 맞는 첫 번째 레코드를 찾은 후 전체 테이블을 정렬하는 대신 정렬이 종료됩니다.
l LIMIT n과 DISTINCT를 함께 사용하면 MySQL은 레코드를 찾은 후 쿼리를 중지합니다.
l 어떤 경우에는 키를 순차적으로 읽거나(또는 키에 따라 정렬) 키 값이 변경될 때까지 요약을 계산하여 GROUP BY를 해결할 수 있습니다. 이 경우 LIMIT n은 불필요한 GROUP을 평가하지 않습니다.
l MySQL이 클라이언트에 n번째 행 전송을 마치면 나머지 쿼리는 중단됩니다.
l 그리고 LIMIT 0 옵션은 항상 빈 레코드를 빠르게 반환합니다. 이는 쿼리를 확인하고 결과 열의 열 유형을 가져오는 데 유용합니다.
l 임시 테이블의 크기는 LIMIT #을 사용하여 쿼리를 해결하는 데 필요한 공간을 계산합니다.

위 내용은 Selllimit의 내용을 포함하여 Selllimit가 MySQL 쿼리를 최적화하기 위해 Limit 매개변수를 사용하는 방법을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP 세션에 저장된 데이터를 어떻게 수정합니까?PHP 세션에 저장된 데이터를 어떻게 수정합니까?Apr 27, 2025 am 12:23 AM

tomodifyDatainAphPessess, startSessionstession_start (), 그런 다음 $ _sessionToset, modify, orremovevariables.

PHP 세션에 배열을 저장하는 예를 제시하십시오.PHP 세션에 배열을 저장하는 예를 제시하십시오.Apr 27, 2025 am 12:20 AM

배열은 PHP 세션에 저장할 수 있습니다. 1. 세션을 시작하고 session_start ()를 사용하십시오. 2. 배열을 만들고 $ _session에 저장하십시오. 3. $ _session을 통해 배열을 검색하십시오. 4. 세션 데이터를 최적화하여 성능을 향상시킵니다.

Garbage Collection은 PHP 세션에 어떻게 효과가 있습니까?Garbage Collection은 PHP 세션에 어떻게 효과가 있습니까?Apr 27, 2025 am 12:19 AM

PHP 세션 쓰레기 수집은 만료 된 세션 데이터를 정리하기위한 확률 메커니즘을 통해 트리거됩니다. 1) 구성 파일에서 트리거 확률 및 세션 수명주기를 설정합니다. 2) CRON 작업을 사용하여 고재 응용 프로그램을 최적화 할 수 있습니다. 3) 데이터 손실을 피하기 위해 쓰레기 수집 빈도 및 성능의 균형을 맞춰야합니다.

PHP에서 세션 활동을 어떻게 추적 할 수 있습니까?PHP에서 세션 활동을 어떻게 추적 할 수 있습니까?Apr 27, 2025 am 12:10 AM

PHP의 사용자 세션 활동 추적은 세션 관리를 통해 구현됩니다. 1) Session_start ()를 사용하여 세션을 시작하십시오. 2) $ _session 배열을 통해 데이터를 저장하고 액세스하십시오. 3) 세션 _destroy ()를 호출하여 세션을 종료합니다. 세션 추적은 사용자 행동 분석, 보안 모니터링 및 성능 최적화에 사용됩니다.

데이터베이스를 사용하여 PHP 세션 데이터를 저장할 수있는 방법은 무엇입니까?데이터베이스를 사용하여 PHP 세션 데이터를 저장할 수있는 방법은 무엇입니까?Apr 27, 2025 am 12:02 AM

데이터베이스를 사용하여 PHP 세션 데이터를 저장하면 성능 및 확장 성을 향상시킬 수 있습니다. 1) 세션 데이터를 저장하기 위해 MySQL 구성 : php.ini 또는 php 코드에서 세션 프로세서를 설정하십시오. 2) 사용자 정의 세션 프로세서 구현 : 데이터베이스와 상호 작용하기 위해 열린, 닫기, 읽기, 쓰기 및 기타 기능을 정의합니다. 3) 최적화 및 모범 사례 : 인덱싱, 캐싱, 데이터 압축 및 분산 스토리지를 사용하여 성능을 향상시킵니다.

PHP 세션의 개념을 간단한 용어로 설명하십시오.PHP 세션의 개념을 간단한 용어로 설명하십시오.Apr 26, 2025 am 12:09 AM

phpsessionstrackuserdataacrossmultiplepagerequestsususingauniqueIdStoredInAcookie.here'showtomanagetheMeftically : 1) STARTASESSIONSTART_START () andSTAREDATAIN $ _SESSION.2) RegenerATERATESSESSIDIDAFTERLOGINWITHSESSION_RATERATERATES (True) TopreventSES

PHP 세션에 저장된 모든 값을 어떻게 반복합니까?PHP 세션에 저장된 모든 값을 어떻게 반복합니까?Apr 26, 2025 am 12:06 AM

PHP에서 세션 데이터를 통한 반복은 다음 단계를 통해 달성 할 수 있습니다. 1. Session_start ()를 사용하여 세션을 시작하십시오. 2. $ _session 배열의 모든 키 값 쌍을 통해 Foreach 루프를 통과합니다. 3. 복잡한 데이터 구조를 처리 할 때 is_array () 또는 is_object () 함수를 사용하고 print_r ()를 사용하여 자세한 정보를 출력하십시오. 4. Traversal을 최적화 할 때 페이징을 사용하여 한 번에 많은 양의 데이터를 처리하지 않도록 할 수 있습니다. 이를 통해 실제 프로젝트에서 PHP 세션 데이터를보다 효율적으로 관리하고 사용하는 데 도움이됩니다.

사용자 인증에 세션을 사용하는 방법을 설명하십시오.사용자 인증에 세션을 사용하는 방법을 설명하십시오.Apr 26, 2025 am 12:04 AM

이 세션은 서버 측 상태 관리 메커니즘을 통해 사용자 인증을 인식합니다. 1) 세션 생성 및 고유 ID의 세션 생성, 2) ID는 쿠키를 통해 전달됩니다. 3) ID를 통해 서버 저장 및 세션 데이터에 액세스합니다. 4) 사용자 인증 및 상태 관리가 실현되어 응용 프로그램 보안 및 사용자 경험이 향상됩니다.

See all articles

핫 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구