如何在 MySQL 中獲取表的第一條和最後一條記錄?


要獲取第一條和最後一條記錄,請使用 UNION。LIMIT 也用於獲取所需的記錄數。

讓我們首先建立一個表 -

mysql> create table DemoTable694 (
   EmployeeId int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   EmployeeName varchar(100),
   EmployeeSalary int
);
Query OK, 0 rows affected (0.58 sec)

使用插入命令向表中插入一些記錄 -

mysql> insert into DemoTable694(EmployeeName,EmployeeSalary) values('Chris',457647);
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable694(EmployeeName,EmployeeSalary) values('Robert',90883);
Query OK, 1 row affected (0.25 sec)
mysql> insert into DemoTable694(EmployeeName,EmployeeSalary) values('David',123532);
Query OK, 1 row affected (0.19 sec)
mysql> insert into DemoTable694(EmployeeName,EmployeeSalary) values('Mike',989322);
Query OK, 1 row affected (0.22 sec)

使用 select 語句顯示錶中的所有記錄 -

mysql> select *from DemoTable694;

這將產生以下輸出 -

+------------+--------------+----------------+
| EmployeeId | EmployeeName | EmployeeSalary |
+------------+--------------+----------------+
| 1          | Chris        | 457647         |
| 2          | Robert       | 90883          |
| 3          | David        | 123532         |
| 4          | Mike         | 989322         |
+------------+--------------+----------------+
4 rows in set (0.00 sec)

以下是獲取第一條和最後一條記錄的查詢 -

mysql> (select *from DemoTable694 order by EmployeeId ASC LIMIT 1)
UNION
(select *from DemoTable694 order by EmployeeId DESC LIMIT 1);

這將產生以下輸出 -

+------------+--------------+----------------+
| EmployeeId | EmployeeName | EmployeeSalary |
+------------+--------------+----------------+
| 1          | Chris        | 457647         |
| 4          | Mike         | 989322         |
+------------+--------------+----------------+
2 rows in set (0.00 sec)

更新於: 21-Aug-2019

18K+ 檢視

開啟您的 職業

完成課程認證

開始
廣告