MySQL - LIMIT 子句



MySQL LIMIT 子句

MySQL 中的LIMIT 子句用于指定要返回的记录数。此子句主要用于处理包含数千条记录的表。它接受一个或两个参数(偏移量或计数)。这两个参数的值都应该是正整数或零。

第一行的偏移量从 0 开始,而不是从 1 开始,第一行的计数从 1 开始。让我们使用下图更好地理解它

Mysql-Limit

假设上述表的名称为students。如果我们执行上述查询,我们将得到 Mahika、Aarohi 和 Nikhil 作为输出。

语法

以下是 MySQL LIMIT 子句的通用语法:

SELECT column1, column2, ... FROM table_name
LIMIT number;
其中,LIMIT 子句指定要从表中返回的最大行数。

示例

以下示例演示了 MySQL LIMIT 查询的使用。

首先,让我们使用以下查询创建一个名为CUSTOMERS的表:

CREATE TABLE CUSTOMERS (
   ID INT NOT NULL,
   NAME VARCHAR (20) NOT NULL,
   AGE INT NOT NULL,
   ADDRESS CHAR (25),
   SALARY DECIMAL (18, 2),       
   PRIMARY KEY (ID)
);

在这里,我们使用以下 INSERT INTO 语句将 7 条记录插入到上面创建的表中:

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) VALUES 
(1, 'Ramesh', 32, 'Ahmedabad', 2000.00 ),
(2, 'Khilan', 25, 'Delhi', 1500.00 ),
(3, 'Kaushik', 23, 'Kota', 2000.00 ),
(4, 'Chaitali', 25, 'Mumbai', 6500.00 ),
(5, 'Hardik', 27, 'Bhopal', 8500.00 ),
(6, 'Komal', 22, 'Hyderabad', 4500.00 ),
(7, 'Muffy', 24, 'Indore', 10000.00 );

执行以下查询以获取 CUSTOMERS 表中存在的所有记录:

SELECT * FROM CUSTOMERS;

以下是 CUSTOMERS 表:

ID 姓名 (NAME) 年龄 (AGE) 地址 (ADDRESS) 薪水 (SALARY)
1 Ramesh 32 Ahmedabad 2000.00
2 Khilan 25 Delhi 1500.00
3 Kaushik 23 Kota 2000.00
4 Chaitali 25 Mumbai 6500.00
5 Hardik 27 Bhopal 8500.00
6 Komal 22 Hyderabad 4500.00
7 Muffy 24 Indore 10000.00

现在,我们使用与 SELECT 语句结合的 MySQL LIMIT 子句从 CUSTOMERS 表中选择前四条记录:

SELECT * FROM CUSTOMERS LIMIT 4;

输出

正如我们在下面的输出中看到的,它返回了 CUSTOMERS 表中的前四行:

ID 姓名 (NAME) 年龄 (AGE) 地址 (ADDRESS) 薪水 (SALARY)
1 Ramesh 32 Ahmedabad 2000.00
2 Khilan 25 Delhi 1500.00
3 Kaushik 23 Kota 2000.00
4 Chaitali 25 Mumbai 6500.00

示例

在下面的查询中,我们从 CUSTOMERS 表中选择从第三行(偏移量 2)开始的四行:

SELECT * FROM CUSTOMERS LIMIT 2,4;

输出

当我们执行上述查询时,将获得如下输出:

ID 姓名 (NAME) 年龄 (AGE) 地址 (ADDRESS) 薪水 (SALARY)
3 Kaushik 23 Kota 2000.00
4 Chaitali 25 Mumbai 6500.00
5 Hardik 27 Bhopal 8500.00
6 Komal 22 Hyderabad 4500.00

LIMIT 与 WHERE 子句结合使用

在 MySQL 中,我们可以将 LIMIT 子句与 WHERE 子句一起在 SELECT 语句中使用,以根据条件指定查询返回的行数。

语法

以下是通用语法:

SELECT column1, column2, ... FROM table_name
WHERE condition
LIMIT number;

示例

在下面的查询中,我们从 CUSTOMERS 表中选择前两行,其中 AGE 大于 21:

SELECT * FROM CUSTOMERS WHERE AGE > 21 LIMIT 2;

输出

执行上述查询后,将显示如下输出:

ID 姓名 (NAME) 年龄 (AGE) 地址 (ADDRESS) 薪水 (SALARY)
1 Ramesh 32 Ahmedabad 2000.00
2 Khilan 25 Delhi 1500.00

示例

在下面的查询中,我们从 CUSTOMERS 表中选择接下来的 3 条记录,从第 2 条记录(偏移量)开始,其中 AGE 列的值大于 21

SELECT * FROM CUSTOMERS WHERE AGE > 21 LIMIT 1,3;

输出

上面查询的输出如下所示:

ID 姓名 (NAME) 年龄 (AGE) 地址 (ADDRESS) 薪水 (SALARY)
2 Khilan 25 Delhi 1500.00
3 Kaushik 23 Kota 2000.00
4 Chaitali 25 Mumbai 6500.00

LIMIT 与 ORDER BY 子句结合使用

ORDER BY 子句将按指定的顺序(ASC 或 DESC)对列的行进行排序。在 MySQL 中,我们可以将 LIMIT 子句与 ORDER BY 子句一起使用,以限制在排序结果集中返回的行数。

语法

以下是 MySQL 中 LIMIT 子句与 WHERE 子句结合使用的语法:

SELECT column1, column2, ... FROM table_name
ORDER BY column_name [ASC|DESC]
LIMIT number;

示例

在下面的查询中,我们从 CUSTOMERS 表中获取所有记录,并按降序对 SALARY 列进行排序。然后,我们从排序结果集中获取 5 行。

SELECT * FROM CUSTOMERS
ORDER BY SALARY DESC
LIMIT 5;

输出

如果我们编译并运行上述查询,则结果将如下所示:

ID 姓名 (NAME) 年龄 (AGE) 地址 (ADDRESS) 薪水 (SALARY)
7 Muffy 24 Indore 10000.00
5 Hardik 27 Bhopal 8500.00
4 Chaitali 25 Mumbai 6500.00
6 Komal 22 Hyderabad 4500.00
1 Ramesh 32 Ahmedabad 2000.00

示例

在这里,我们选择表中的所有记录,并按升序对 SALARY 列进行排序。然后,我们从排序结果集中选择从第二行(偏移量 1)开始的三行:

SELECT * FROM CUSTOMERS
ORDER BY SALARY ASC
LIMIT 1,3;

输出

执行给定查询后,将显示如下输出:

ID 姓名 (NAME) 年龄 (AGE) 地址 (ADDRESS) 薪水 (SALARY)
1 Ramesh 32 Ahmedabad 2000.00
3 Kaushik 23 Kota 2000.00
6 Komal 22 Hyderabad 4500.00

使用客户端程序的 LIMIT 子句

除了使用 MySQL 查询限制从表中返回的记录数外,我们还可以使用客户端程序执行 LIMIT 操作。

语法

以下是各种编程语言中此操作的语法:

要通过 PHP 程序限制从表中返回的记录数,我们需要使用mysqli 函数query()执行带有 'LIMIT' 子句的 'SELECT' 语句,如下所示:

$sql = "SELECT * FROM tutorials_tbl WHERE tutorial_title = 'Java Tutorial' LIMIT 3";
$mysqli->query($sql);

要限制通过 Node.js 程序从表中返回的记录数量,我们需要使用mysql2库的query()函数执行带有 'LIMIT' 子句的 'SELECT' 语句,如下所示:

sql = "SELECT * FROM CUSTOMERS LIMIT 4";
con.query(sql);  

要限制通过 Java 程序从表中返回的记录数量,我们需要使用JDBC函数executeUpdate()执行带有 'LIMIT' 子句的 'SELECT' 语句,如下所示:

String sql = "SELECT * FROM CUSTOMERS LIMIT 4";
statement.executeQuery(sql);

要限制通过 Python 程序从表中返回的记录数量,我们需要使用MySQL Connector/Pythonexecute()函数执行带有 'LIMIT' 子句的 'SELECT' 语句,如下所示:

limit_query = "SELECT * FROM tutorials_tbl LIMIT {limit_value}"
cursorObj.execute(limit_query)

示例

以下是程序:

$dbhost = 'localhost';
$dbuser = 'root';
$dbpass = 'password';
$dbname = 'TUTORIALS';
$mysqli = new mysqli($dbhost, $dbuser, $dbpass, $dbname);
if($mysqli->connect_errno ) {
   printf("Connect failed: %s
", $mysqli->connect_error); exit(); } //printf('Connected successfully.
'); $sql = "SELECT * FROM tutorials_tbl WHERE tutorial_title = 'Java Tutorial' LIMIT 3"; if($result = $mysqli->query($sql)){ printf("SELECT LIMIT statement executed successfully..! "); printf("Records are(limit 3): "); while($row = mysqli_fetch_row($result)){ print_r ($row); } } if($mysqli->error){ printf("Failed..!" , $mysqli->error); } $mysqli->close();

输出

获得的输出如下:

SELECT LIMIT statement executed successfully..!  Records are(limit 3): Array
(
    [0] => 1
    [1] => Java Tutorial
    [2] => new_author
    [3] =>
)
Array
(
    [0] => 3
    [1] => Java Tutorial
    [2] => newauther1
    [3] => 2023-12-20
)
Array
(
    [0] => 4
    [1] => Java Tutorial
    [2] => newauther2
    [3] => 2022-06-10
)  
var mysql = require('mysql2');
var con = mysql.createConnection({
    host: "localhost",
    user: "root",
    password: "Nr5a0204@123"
});

  //Connecting to MySQL
  con.connect(function (err) {
  if (err) throw err;
  console.log("Connected!");

  //Selecting a Database
  sql = "USE TUTORIALS"
  con.query(sql);

  //Creating a table
  sql = "CREATE TABLE CUSTOMERS (ID INT NOT NULL,NAME VARCHAR (20) NOT NULL,AGE INT NOT NULL,ADDRESS CHAR (25),SALARY DECIMAL (18, 2),PRIMARY KEY (ID));"
  con.query(sql);

  //Inserting Records
  sql = "INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) VALUES (1, 'Ramesh',32, 'Ahmedabad', 2000.00 ), (2, 'Khilan',25, 'Delhi', 1500.00 ),(3, 'kaushik',23, 'Kota', 2000.00 ), (4,'Chaitali', 25, 'Mumbai', 6500.00 ), (5, 'Hardik',27, 'Bhopal', 8500.00 ), (6, 'Komal',22, 'MP', 4500.00 ), (7, 'Muffy',24, 'Indore', 10000.00 );"
  con.query(sql);

  sql = "SELECT * FROM CUSTOMERS LIMIT 4"
  con.query(sql, function (err, result) {
      if (err) throw err;
      console.log(result);
  });
});          

输出

生成的输出如下:

Connected!
[
  {
    ID: 1,
    NAME: 'Ramesh',
    AGE: 32,
    ADDRESS: 'Ahmedabad',
    SALARY: '2000.00'
  },
  {
    ID: 2,
    NAME: 'Khilan',
    AGE: 25,
    ADDRESS: 'Delhi',
    SALARY: '1500.00'
  },
  {
    ID: 3,
    NAME: 'kaushik',
    AGE: 23,
    ADDRESS: 'Kota',
    SALARY: '2000.00'
  },
  {
    ID: 4,
    NAME: 'Chaitali',
    AGE: 25,
    ADDRESS: 'Mumbai',
    SALARY: '6500.00'
  }
]       
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
public class LimitQuery {
  public static void main(String[] args) {
    String url = "jdbc:mysql://127.0.0.1:3306/TUTORIALS";
    String user = "root";
    String password = "password";
    ResultSet rs;
    try {
      Class.forName("com.mysql.cj.jdbc.Driver");
            Connection con = DriverManager.getConnection(url, user, password);
            Statement st = con.createStatement();
            //System.out.println("Database connected successfully...!");
            String sql = "SELECT * FROM CUSTOMERS LIMIT 4";
            rs = st.executeQuery(sql);
            System.out.println("Table records: ");
            while(rs.next()) {
              String Id = rs.getString("Id");
              String Name = rs.getString("Name");
              String Age = rs.getString("Age");
              String Address = rs.getString("Address");
              String Salary = rs.getString("Salary");
              System.out.println("Id: " + Id + ", Name: " + Name + ", Age: " +  Age + ", Address: " + Address + ", Salary: " + Salary);
            }
    }catch(Exception e) {
      e.printStackTrace();
    }
  }
}

输出

获得的输出如下所示:

Table records: 
Id: 1, Name: Ramesh, Age: 32, Address: Ahmedabad, Salary: 2000.00
Id: 2, Name: Khilan, Age: 25, Address: Delhi, Salary: 1500.00
Id: 3, Name: kaushik, Age: 23, Address: Kota, Salary: 2000.00
Id: 4, Name: Chaitali, Age: 25, Address: Mumbai, Salary: 6500.00 
import mysql.connector
#establishing the connection
connection = mysql.connector.connect(
    host='localhost',
    user='root',
    password='password',
    database='tut'
)
cursorObj = connection.cursor()
limit_value = 3
limit_query = f"SELECT * FROM tutorials_tbl LIMIT {limit_value}"
cursorObj.execute(limit_query)
result = cursorObj.fetchall()
print(f"First {limit_value} rows from Tutorial Table:")
for row in result:
    print(row)
cursorObj.close()
connection.close()           

输出

以下是上述代码的输出:

First 3 rows from Tutorial Table:
(1, 'Learn PHP', 'John Paul', datetime.date(2023, 3, 28))
(2, 'Learn MySQL', 'Abdul S', datetime.date(2023, 3, 28))
(3, 'JAVA Tutorial', 'Sanjay', datetime.date(2007, 5, 6))
广告