Cách chọn dữ liệu cụ thể trong MySQL

Phần này của hướng dẫn MySQL sẽ trình bày chi tiết về câu lệnh mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 0 mà MySQL hiểu được

Câu lệnh SQL sau đây là một trong những câu lệnh phổ biến nhất. Nó cũng là một trong những cái đắt nhất

mysql> SELECT * FROM Cars; +----+------------+--------+ | Id | Name | Cost | +----+------------+--------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | | 7 | Hummer | 41400 | | 8 | Volkswagen | 21600 | +----+------------+--------+ 8 rows in set (0.00 sec)

Ở đây chúng tôi lấy tất cả dữ liệu từ bảng mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 1

Chọn các cột cụ thể

Chúng ta có thể sử dụng câu lệnh mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 0 để truy xuất các cột cụ thể. Tên cột theo sau từ mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 0

mysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec)

Chúng tôi lấy các cột mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 4 và mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 5. Các tên cột cách nhau bởi dấu phẩy

Đổi tên tên cột

Chúng ta có thể đổi tên tên cột của tập kết quả trả về. Đối với điều này, chúng tôi sử dụng mệnh đề mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 6

mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec)

Giả sử chúng tôi muốn đặt tên cho cột giá thay vì chi phí. Với câu lệnh SQL trên, chúng ta đã hoàn thành việc này

Hạn chế xuất dữ liệu

Như chúng tôi đã đề cập ở trên, việc truy xuất tất cả dữ liệu rất tốn kém khi xử lý lượng dữ liệu lớn. Chúng ta có thể sử dụng mệnh đề mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 7 để giới hạn lượng dữ liệu được trả về bởi câu lệnh

mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec)

Mệnh đề mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 7 giới hạn số hàng trả về là 4

Với hai đối số, mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 7 trả về các hàng bắt đầu từ một giá trị offset

mysql> SELECT * FROM Cars LIMIT 2, 4; +----+---------+--------+ | Id | Name | Cost | +----+---------+--------+ | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | +----+---------+--------+ 4 rows in set (0.00 sec)

Giá trị đầu tiên là phần bù và giá trị thứ hai là số hàng được trả về. Ở đây chúng tôi chọn tất cả dữ liệu từ tối đa bốn hàng và chúng tôi bắt đầu với hàng thứ ba

mysql> SELECT * FROM Cars LIMIT 4 OFFSET 2; +----+---------+--------+ | Id | Name | Cost | +----+---------+--------+ | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | +----+---------+--------+ 4 rows in set (0.00 sec)

Để tương thích với cơ sở dữ liệu PostgreSQL, MySQL cũng có từ khóa mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec) 0. Đoạn mã trên tương đương với ví dụ trước

Chúng tôi sử dụng mệnh đề mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec) 1 để sắp xếp tập dữ liệu được trả về. Mệnh đề mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec) 1 được theo sau bởi cột mà chúng ta sắp xếp. Từ khóa mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec) 3 sắp xếp dữ liệu theo thứ tự tăng dần, từ khóa mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec) 4 theo thứ tự giảm dần

mysql> SELECT Name, Cost FROM Cars ORDER BY Cost DESC; +------------+--------+ | Name | Cost | +------------+--------+ | Bentley | 350000 | | Mercedes | 57127 | | Audi | 52642 | | Hummer | 41400 | | Volvo | 29000 | | Volkswagen | 21600 | | Citroen | 21000 | | Skoda | 9000 | +------------+--------+ 8 rows in set (0.00 sec)

Trong câu lệnh SQL trên, chúng tôi chọn các cột tên, chi phí từ bảng mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 1 và sắp xếp nó theo chi phí của những chiếc ô tô theo thứ tự giảm dần. Vì vậy, những chiếc xe đắt tiền nhất đến trước

Chọn các hàng cụ thể với mệnh đề WHERE

Trong các ví dụ sau, chúng ta sẽ sử dụng bảng mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec) 6

Quảng cáomysql> SELECT * FROM Orders; +----+------------+------------+ | Id | OrderPrice | Customer | +----+------------+------------+ | 1 | 1200 | Williamson | | 2 | 200 | Robertson | | 3 | 40 | Robertson | | 4 | 1640 | Smith | | 5 | 100 | Robertson | | 6 | 50 | Williamson | | 7 | 150 | Smith | | 8 | 250 | Smith | | 9 | 840 | Brown | | 10 | 440 | Black | | 11 | 20 | Brown | +----+------------+------------+ 11 rows in set (0.00 sec)

Ở đây chúng ta thấy tất cả dữ liệu từ bảng mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec) 6

Tiếp theo, chúng tôi muốn chọn một hàng cụ thể

mysql> SELECT * FROM Orders WHERE Id=6; +----+------------+------------+ | Id | OrderPrice | Customer | +----+------------+------------+ | 6 | 50 | Williamson | +----+------------+------------+ 1 row in set (0.00 sec)

Câu lệnh SQL trên chọn một hàng có Id 6

mysql> SELECT * FROM Orders WHERE Customer="Smith"; +----+------------+----------+ | Id | OrderPrice | Customer | +----+------------+----------+ | 4 | 1640 | Smith | | 7 | 150 | Smith | | 8 | 250 | Smith | +----+------------+----------+ 3 rows in set (0.00 sec)

Câu lệnh SQL trên chọn tất cả các đơn đặt hàng được tạo bởi khách hàng Smith

Chúng ta có thể sử dụng từ khóa mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec) 8 để tìm kiếm một mẫu cụ thể trong dữ liệu

mysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 0

Câu lệnh SQL này chọn tất cả các đơn đặt hàng từ khách hàng có tên bắt đầu bằng ký tự B

Từ khóa mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec) 9 được sử dụng để chỉ chọn các mục duy nhất từ ​​tập kết quả

mysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 1

Lần này chúng tôi đã chọn những khách hàng có tên bắt đầu bằng ký tự B. Chúng ta có thể thấy rằng Brown được nhắc đến hai lần. Để loại bỏ trùng lặp, chúng tôi sử dụng từ khóa mysql> SELECT * FROM Cars LIMIT 4; +----+----------+-------+ | Id | Name | Cost | +----+----------+-------+ | 1 | Audi | 52642 | | 2 | Mercedes | 57127 | | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | +----+----------+-------+ 4 rows in set (0.00 sec) 9

Quảng cáomysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 2

Đây là giải pháp chính xác

Giả sử chúng ta muốn biết có bao nhiêu đơn hàng được đặt bởi khách hàng Brown. Chúng tôi sẽ sử dụng chức năng mysql> SELECT * FROM Cars LIMIT 2, 4; +----+---------+--------+ | Id | Name | Cost | +----+---------+--------+ | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | +----+---------+--------+ 4 rows in set (0.00 sec) 1

mysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 3

Khách hàng đã đặt hai đơn hàng

Nhóm dữ liệu

Mệnh đề mysql> SELECT * FROM Cars LIMIT 2, 4; +----+---------+--------+ | Id | Name | Cost | +----+---------+--------+ | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | +----+---------+--------+ 4 rows in set (0.00 sec) 2 được sử dụng để kết hợp các bản ghi cơ sở dữ liệu với các giá trị giống hệt nhau thành một bản ghi duy nhất. Nó thường được sử dụng với các chức năng tổng hợp

Giả sử chúng tôi muốn tìm hiểu, tổng số đơn đặt hàng của từng khách hàng

mysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 4

Từ khóa mysql> SELECT * FROM Cars LIMIT 2, 4; +----+---------+--------+ | Id | Name | Cost | +----+---------+--------+ | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | +----+---------+--------+ 4 rows in set (0.00 sec) 3 trả về tổng của một cột số. Mệnh đề mysql> SELECT * FROM Cars LIMIT 2, 4; +----+---------+--------+ | Id | Name | Cost | +----+---------+--------+ | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | +----+---------+--------+ 4 rows in set (0.00 sec) 2 chia tổng số tiền cho các khách hàng. Vì vậy, chúng ta có thể thấy rằng Đen đã đặt hàng với giá 440 hoặc Smith cho 2040

Chúng ta không thể sử dụng mệnh đề mysql> SELECT * FROM Cars LIMIT 2, 4; +----+---------+--------+ | Id | Name | Cost | +----+---------+--------+ | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | +----+---------+--------+ 4 rows in set (0.00 sec) 5 khi các hàm tổng hợp đã được sử dụng. Thay vào đó, chúng tôi sử dụng mệnh đề mysql> SELECT * FROM Cars LIMIT 2, 4; +----+---------+--------+ | Id | Name | Cost | +----+---------+--------+ | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | +----+---------+--------+ 4 rows in set (0.00 sec) 6

mysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 5

Câu lệnh SQL trên chọn khách hàng có tổng số đơn đặt hàng lớn hơn 1000 đơn vị

Câu lệnh mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 0 có thể được sử dụng để ghi dữ liệu từ các bảng vào một tệp

mysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 6

Chúng tôi ghi dữ liệu từ bảng mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 1 vào tệp mysql> SELECT * FROM Cars LIMIT 2, 4; +----+---------+--------+ | Id | Name | Cost | +----+---------+--------+ | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | +----+---------+--------+ 4 rows in set (0.00 sec) 9. Tệp đầu ra là tệp CSV (Giá trị được phân tách bằng dấu phẩy). Lưu ý rằng thao tác này dễ bị lỗi, chúng ta có thể dễ dàng gặp phải lỗi từ chối quyền

mysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 7

Chúng ta có thể thực hiện thao tác ngược lại;

mysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 8

Chúng tôi xóa tất cả các hàng khỏi bảng mysql> SELECT Name, Cost AS Price FROM Cars; +------------+--------+ | Name | Price | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 1

Quảng cáomysql> SELECT Name, Cost FROM Cars; +------------+--------+ | Name | Cost | +------------+--------+ | Audi | 52642 | | Mercedes | 57127 | | Skoda | 9000 | | Volvo | 29000 | | Bentley | 350000 | | Citroen | 21000 | | Hummer | 41400 | | Volkswagen | 21600 | +------------+--------+ 8 rows in set (0.00 sec) 9

Chúng tôi sử dụng câu lệnh mysql> SELECT * FROM Cars LIMIT 4 OFFSET 2; +----+---------+--------+ | Id | Name | Cost | +----+---------+--------+ | 3 | Skoda | 9000 | | 4 | Volvo | 29000 | | 5 | Bentley | 350000 | | 6 | Citroen | 21000 | +----+---------+--------+ 4 rows in set (0.00 sec) 1 để tải lại dữ liệu vào bảng. Chúng tôi xác minh rằng dữ liệu đã được tải chính xác

Chủ đề