mysql에서 쿼리 수를 제한하는 방법
mysql에서는 "LIMIT" 절을 사용하여 쿼리 수를 제한할 수 있습니다. 이 절은 SELECT 쿼리 결과에 의해 반환되는 항목 수를 제한할 수 있습니다. 구문은 "SELECT column1, column2,... FROM table LIMIT입니다. 오프셋, 개수;" .
이 튜토리얼의 운영 환경: windows7 시스템, mysql8 버전, Dell G3 컴퓨터.
데이터 테이블에 수만 개의 데이터가 있는 경우 테이블의 모든 데이터를 한 번에 쿼리하면 데이터 반환 속도가 느려지고 데이터베이스 서버에 많은 부담을 줄 수 있습니다. 이때 LIMIT 절을 사용하여 반환되는 쿼리 결과의 개수를 제한할 수 있습니다.
LIMIT는 쿼리 결과가 표시되기 시작하는 레코드와 총 표시되는 레코드 수를 지정하는 데 사용되는 MySQL의 특수 키워드입니다.
1. MySQL LIMIT 절 소개
SELECT
문의 LIMIT
절을 사용하여 결과 집합의 행 수를 제한하세요. LIMIT
절은 하나 또는 두 개의 매개변수를 허용합니다. 두 매개변수의 값은 모두 0 또는 양의 정수여야 합니다. SELECT
语句中使用LIMIT
子句来约束结果集中的行数。LIMIT
子句接受一个或两个参数。两个参数的值必须为零或正整数。
下面说明了两个参数的LIMIT
子句语法:
SELECT column1,column2,... FROM table LIMIT offset , count;
我们来查看LIMIT
子句参数:
offset
参数指定要返回的第一行的偏移量。第一行的偏移量为0
,而不是1
。count
指定要返回的最大行数。
当您使用带有一个参数的LIMIT
子句时,此参数将用于确定从结果集的开头返回的最大行数。
SELECT column1,column2,... FROM table LIMIT count;
上面的查询等同于下面接受两个参数的LIMIT
子句的查询:
SELECT column1,column2,... FROM table LIMIT 0 , count;
2. 使用MySQL LIMIT获取前N行
可以使用LIMIT
子句来选择表中的前N
行记录,如下所示:
SELECT column1,column2,... FROM table LIMIT N;
例如,要查询employees
表中前5
个客户,请使用以下查询:
SELECT customernumber, customername, creditlimit FROM customers LIMIT 5;
或者 -
SELECT customernumber, customername, creditlimit FROM customers LIMIT 0,5;
执行上面语句,得到以下结果 -
mysql> SELECT customernumber, customername, creditlimit FROM customers LIMIT 5; +----------------+----------------------------+-------------+ | customernumber | customername | creditlimit | +----------------+----------------------------+-------------+ | 103 | Atelier graphique | 21000 | | 112 | Signal Gift Stores | 71800 | | 114 | Australian Collectors, Co. | 117300 | | 119 | La Rochelle Gifts | 118200 | | 121 | Baane Mini Imports | 81700 | +----------------+----------------------------+-------------+ 5 rows in set
3. 使用MySQL LIMIT获得最高和最低的值
LIMIT
子句经常与ORDER BY子句一起使用。首先,使用ORDER BY
子句根据特定条件对结果集进行排序,然后使用LIMIT
子句来查找最小或最大值。
注意:
ORDER BY
子句按指定字段排序的使用。
请参见示例数据库(yiibaidb)中的以下customers
表,其表结构如下所示 -
mysql> desc customers; +------------------------+---------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +------------------------+---------------+------+-----+---------+-------+ | customerNumber | int(11) | NO | PRI | NULL | | | customerName | varchar(50) | NO | | NULL | | | contactLastName | varchar(50) | NO | | NULL | | | contactFirstName | varchar(50) | NO | | NULL | | | phone | varchar(50) | NO | | NULL | | | addressLine1 | varchar(50) | NO | | NULL | | | addressLine2 | varchar(50) | YES | | NULL | | | city | varchar(50) | NO | | NULL | | | state | varchar(50) | YES | | NULL | | | postalCode | varchar(15) | YES | | NULL | | | country | varchar(50) | NO | | NULL | | | salesRepEmployeeNumber | int(11) | YES | MUL | NULL | | | creditLimit | decimal(10,2) | YES | | NULL | | +------------------------+---------------+------+-----+---------+-------+ 13 rows in set
例如,要查询信用额度最高的前五名客户,请使用以下查询:
SELECT customernumber, customername, creditlimit FROM customers ORDER BY creditlimit DESC LIMIT 5;
执行上面查询语句,得到以下结果 -
mysql> SELECT customernumber, customername, creditlimit FROM customers ORDER BY creditlimit DESC LIMIT 5; +----------------+------------------------------+-------------+ | customernumber | customername | creditlimit | +----------------+------------------------------+-------------+ | 141 | Euro+ Shopping Channel | 227600 | | 124 | Mini Gifts Distributors Ltd. | 210500 | | 298 | Vida Sport, Ltd | 141300 | | 151 | Muscle Machine Inc | 138500 | | 187 | AV Stores, Co. | 136800 | +----------------+------------------------------+-------------+ 5 rows in set
以下查询将返回信用限额最低的五位客户:
SELECT customernumber, customername, creditlimit FROM customers ORDER BY creditlimit ASC LIMIT 5;
4. 使用MySQL LIMIT获得第n个最高值
MySQL中最棘手的问题之一是:如何获得结果集中的第n
个最高值,例如查询第二(或第n
)贵的产品是哪个,显然不能使用MAX或MIN这样的函数来查询获得。 但是,我们可以使用MySQL LIMIT
来解决这样的问题。
- 首先,按照降序对结果集进行排序。
- 第二步,使用
LIMIT
子句获得第n
贵的产品。
通用查询如下:
SELECT column1, column2,... FROM table ORDER BY column1 DESC LIMIT nth-1, count;
下面我们来看看一个例子,将使用示例数据库(yiibaidb)中的产品(products
)表来进行演示。products
表的结构如下所示 -
mysql> desc products; +--------------------+---------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------------------+---------------+------+-----+---------+-------+ | productCode | varchar(15) | NO | PRI | NULL | | | productName | varchar(70) | NO | | NULL | | | productLine | varchar(50) | NO | MUL | NULL | | | productScale | varchar(10) | NO | | NULL | | | productVendor | varchar(50) | NO | | NULL | | | productDescription | text | NO | | NULL | | | quantityInStock | smallint(6) | NO | | NULL | | | buyPrice | decimal(10,2) | NO | | NULL | | | MSRP | decimal(10,2) | NO | | NULL | | +--------------------+---------------+------+-----+---------+-------+ 9 rows in set
查看以下产品表中的行记录:
mysql> SELECT productCode, productName, buyprice FROM products ORDER BY buyprice DESC; +-------------+--------------------------------------+----------+ | productCode | productName | buyprice | +-------------+--------------------------------------+----------+ | S10_4962 | 1962 LanciaA Delta 16V | 103.42 | | S18_2238 | 1998 Chrysler Plymouth Prowler | 101.51 | | S10_1949 | 1952 Alpine Renault 1300 | 98.58 | | S24_3856 | 1956 Porsche 356A Coupe | 98.3 | | S12_1108 | 2001 Ferrari Enzo | 95.59 | | S12_1099 | 1968 Ford Mustang | 95.34 | ... .... +-------------+--------------------------------------+----------+ 110 rows in set
我们的任务找出结果集中价格第二高的产品。可以使用LIMIT
子句来选择第二行,如以下查询(注意:偏移量从0
开始,所以要指定从1
开始,然后取一行记录):
SELECT productCode, productName, buyprice FROM products ORDER BY buyprice DESC LIMIT 1, 1;
执行上面查询语句,得到以下结果 -
mysql> SELECT productCode, productName, buyprice FROM products ORDER BY buyprice DESC LIMIT 1, 1; +-------------+--------------------------------+----------+ | productCode | productName | buyprice | +-------------+--------------------------------+----------+ | S18_2238 | 1998 Chrysler Plymouth Prowler | 101.51 | +-------------+--------------------------------+----------+ 1 row in set
类似的,获取售价第三高、第四高的产品信息为:LIMIT 2, 1
和 LIMIT 3, 1
LIMIT
절 구문은 아래에 설명되어 있습니다. rrreee LIMIT
절 매개변수를 살펴보겠습니다.
-
offset
매개변수는 반환될 첫 번째 행의 오프셋을 지정합니다. 첫 번째 줄의 오프셋은1
이 아니라0
입니다. -
count
반환할 최대 행 수를 지정합니다.

LIMIT
절을 사용하는 경우 이 매개변수는 결과 집합의 시작 부분에서 반환할 최대 행 수를 결정하는 데 사용됩니다. 🎜rrreee🎜위 쿼리는 두 개의 매개변수가 있는 LIMIT
절을 허용하는 다음 쿼리와 동일합니다. 🎜rrreee2. MySQL LIMIT는 첫 번째 N 행을 가져옵니다🎜🎜아래 표시된 대로 LIMIT
절을 사용하여 테이블에서 레코드의 첫 번째 N
행을 선택할 수 있습니다. 🎜rrreee🎜예를 들어 , 를 쿼리하려면 직원
테이블의 첫 번째 5
고객에 대해 다음 쿼리를 사용하십시오. 🎜rrreee🎜 또는 -🎜rrreee🎜 위 명령문을 실행하면 다음 결과가 나타납니다. -🎜rrreee3. MySQL LIMIT를 사용하여 최고값과 최저값 얻기 🎜🎜 LIMIT
절은 종종 다음과 함께 사용됩니다. ORDER BY 절. 먼저 ORDER BY
절을 사용하여 특정 기준에 따라 결과 집합을 정렬한 다음 LIMIT
절을 사용하여 최소값 또는 최대값을 찾습니다. 🎜🎜🎜참고: 지정된 필드별로 정렬하려면 ORDER BY
절을 사용하세요. 🎜🎜🎜샘플 데이터베이스(yiibaidb)에서 다음 customers
테이블을 참조하세요. 테이블 구조는 다음과 같습니다. - 🎜rrreee🎜예를 들어 신용 한도가 가장 높은 상위 5명의 고객을 쿼리하려면 다음을 사용하세요. 다음 쿼리 :🎜rrreee🎜위 쿼리 문을 실행하여 다음 결과를 얻습니다. -🎜rrreee🎜다음 쿼리는 신용 한도가 가장 낮은 5명의 고객을 반환합니다.🎜rrreee🎜🎜4. MySQL LIMIT를 사용하여 n번째로 높은 값을 얻으세요 🎜🎜MySQL에서 가장 어려운 문제 중 하나는 다음과 같이 결과 집합에서 n
번째로 높은 값을 얻는 방법입니다. 두 번째(또는 n
) 쿼리 중 가장 비싼 제품은 무엇입니까? 물론 MAX 또는 MIN과 같은 함수를 사용하여 쿼리할 수는 없습니다. 그러나 MySQL LIMIT
를 사용하여 이러한 문제를 해결할 수 있습니다. 🎜
-
먼저 결과 집합을 내림차순으로 정렬합니다.
-
두 번째 단계는
LIMIT
절을 사용하여 n
번째로 가장 비싼 제품을 얻는 것입니다.
🎜일반 쿼리는 다음과 같습니다. 🎜rrreee🎜샘플 데이터베이스(yiibaidb)의 제품(products
) 테이블을 사용하여 아래 예를 살펴보겠습니다. 데모. products
테이블의 구조는 다음과 같습니다. - 🎜rrreee🎜다음 제품 테이블의 행을 살펴보세요. 🎜rrreee🎜 우리의 임무는 결과 집합에서 두 번째로 높은 가격의 제품을 찾는 것입니다. 다음 쿼리와 같이 LIMIT
절을 사용하여 두 번째 행을 선택할 수 있습니다(참고: 오프셋은 0
에서 시작하므로 1
에서 지정). > 시작하고 한 줄의 레코드를 가져옵니다): 🎜rrreee🎜위 쿼리문을 실행하면 다음과 같은 결과가 나옵니다. -🎜rrreee🎜마찬가지로 세 번째와 네 번째로 높은 판매 가격의 제품 정보를 가져옵니다: LIMIT 2, 1 code> 및 <code>LIMIT 3, 1
. 🎜🎜【관련 추천: 🎜mysql 비디오 튜토리얼🎜】🎜
LIMIT
절은 종종 다음과 함께 사용됩니다. ORDER BY 절. 먼저 ORDER BY
절을 사용하여 특정 기준에 따라 결과 집합을 정렬한 다음 LIMIT
절을 사용하여 최소값 또는 최대값을 찾습니다. 🎜🎜🎜참고: 지정된 필드별로 정렬하려면 ORDER BY
절을 사용하세요. 🎜🎜🎜샘플 데이터베이스(yiibaidb)에서 다음 customers
테이블을 참조하세요. 테이블 구조는 다음과 같습니다. - 🎜rrreee🎜예를 들어 신용 한도가 가장 높은 상위 5명의 고객을 쿼리하려면 다음을 사용하세요. 다음 쿼리 :🎜rrreee🎜위 쿼리 문을 실행하여 다음 결과를 얻습니다. -🎜rrreee🎜다음 쿼리는 신용 한도가 가장 낮은 5명의 고객을 반환합니다.🎜rrreee🎜🎜4. MySQL LIMIT를 사용하여 n번째로 높은 값을 얻으세요 🎜🎜MySQL에서 가장 어려운 문제 중 하나는 다음과 같이 결과 집합에서 n
번째로 높은 값을 얻는 방법입니다. 두 번째(또는 n
) 쿼리 중 가장 비싼 제품은 무엇입니까? 물론 MAX 또는 MIN과 같은 함수를 사용하여 쿼리할 수는 없습니다. 그러나 MySQL LIMIT
를 사용하여 이러한 문제를 해결할 수 있습니다. 🎜
-
먼저 결과 집합을 내림차순으로 정렬합니다.
-
두 번째 단계는
LIMIT
절을 사용하여 n
번째로 가장 비싼 제품을 얻는 것입니다.
🎜일반 쿼리는 다음과 같습니다. 🎜rrreee🎜샘플 데이터베이스(yiibaidb)의 제품(products
) 테이블을 사용하여 아래 예를 살펴보겠습니다. 데모. products
테이블의 구조는 다음과 같습니다. - 🎜rrreee🎜다음 제품 테이블의 행을 살펴보세요. 🎜rrreee🎜 우리의 임무는 결과 집합에서 두 번째로 높은 가격의 제품을 찾는 것입니다. 다음 쿼리와 같이 LIMIT
절을 사용하여 두 번째 행을 선택할 수 있습니다(참고: 오프셋은 0
에서 시작하므로 1
에서 지정). > 시작하고 한 줄의 레코드를 가져옵니다): 🎜rrreee🎜위 쿼리문을 실행하면 다음과 같은 결과가 나옵니다. -🎜rrreee🎜마찬가지로 세 번째와 네 번째로 높은 판매 가격의 제품 정보를 가져옵니다: LIMIT 2, 1 code> 및 <code>LIMIT 3, 1
. 🎜🎜【관련 추천: 🎜mysql 비디오 튜토리얼🎜】🎜
LIMIT
절을 사용하여 n
번째로 가장 비싼 제품을 얻는 것입니다. 위 내용은 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)

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

MySQL 및 Phpmyadmin은 강력한 데이터베이스 관리 도구입니다. 1) MySQL은 데이터베이스 및 테이블을 작성하고 DML 및 SQL 쿼리를 실행하는 데 사용됩니다. 2) PHPMYADMIN은 데이터베이스 관리, 테이블 구조 관리, 데이터 운영 및 사용자 권한 관리에 직관적 인 인터페이스를 제공합니다.

다른 프로그래밍 언어와 비교할 때 MySQL은 주로 데이터를 저장하고 관리하는 데 사용되는 반면 Python, Java 및 C와 같은 다른 언어는 논리적 처리 및 응용 프로그램 개발에 사용됩니다. MySQL은 데이터 관리 요구에 적합한 고성능, 확장 성 및 크로스 플랫폼 지원으로 유명하며 다른 언어는 데이터 분석, 엔터프라이즈 애플리케이션 및 시스템 프로그래밍과 같은 해당 분야에서 이점이 있습니다.

기사 요약 :이 기사는 Laravel 프레임 워크를 쉽게 설치하는 방법에 대한 독자들을 안내하기위한 자세한 단계별 지침을 제공합니다. Laravel은 웹 애플리케이션의 개발 프로세스를 가속화하는 강력한 PHP 프레임 워크입니다. 이 자습서는 시스템 요구 사항에서 데이터베이스 구성 및 라우팅 설정에 이르기까지 설치 프로세스를 다룹니다. 이러한 단계를 수행함으로써 독자들은 라벨 프로젝트를위한 탄탄한 토대를 빠르고 효율적으로 놓을 수 있습니다.

MySQL에서 외국 키의 기능은 테이블 간의 관계를 설정하고 데이터의 일관성과 무결성을 보장하는 것입니다. 외국 키는 참조 무결성 검사 및 계단식 작업을 통해 데이터의 효과를 유지합니다. 성능 최적화에주의를 기울이고 사용할 때 일반적인 오류를 피하십시오.

MySQL과 Mariadb의 주요 차이점은 성능, 기능 및 라이센스입니다. 1. MySQL은 Oracle에 의해 개발되었으며 Mariadb는 포크입니다. 2. MariaDB는 높은 하중 환경에서 더 나은 성능을 발휘할 수 있습니다. 3. Mariadb는 더 많은 스토리지 엔진과 기능을 제공합니다. 4.MySQL은 듀얼 라이센스를 채택하고 MariaDB는 완전히 오픈 소스입니다. 선택할 때 기존 인프라, 성능 요구 사항, 기능 요구 사항 및 라이센스 비용을 고려해야합니다.

기사의 첫 번째 단락의 초록 : Yi 프레임 워크 응용 프로그램을 개발하기위한 소프트웨어를 선택할 때 여러 가지 요소를 고려해야합니다. Xcode 및 Android Studio와 같은 기본 모바일 애플리케이션 개발 도구는 강력한 제어 및 유연성을 제공 할 수 있지만 React Native 및 Flut 모바일 개발에 새로운 개발자의 경우 AppSheet 및 Glide와 같은 저 코드 또는 노 코드 플랫폼이 응용 프로그램을 빠르고 쉽게 구축 할 수 있습니다. 또한 AWS Amplify 및 Firebase와 같은 클라우드 서비스 제공 업체는 포괄적 인 도구를 제공합니다.

SQL은 관계형 데이터베이스를 관리하는 표준 언어이며 MySQL은 SQL을 사용하는 데이터베이스 관리 시스템입니다. SQL은 CRUD 작업을 포함한 데이터베이스와 상호 작용하는 방법을 정의하는 반면 MySQL은 SQL 표준을 구현하고 저장 프로 시저 및 트리거와 같은 추가 기능을 제공합니다.
