06/04/2021, 14:50

Cách lấy record thứ n trong MySQL - MySQL nâng cao

Trong bài viết này mình sẽ hướng dẫn bạn cách chọn bản ghi thứ n trong MySQL bằng kỹ thuật sử dụng lệnh LIMIT. Như bạn biết, thật dễ dàng để lấy dữ liệu mới nhất hoặc cũ nhất bằng cách sử dụng lệnh order by và limit. Nhưng đôi khi bạn muốn lấy record thứ x trong kết quả trả về thì làm thế nào? ...

Trong bài viết này mình sẽ hướng dẫn bạn cách chọn bản ghi thứ n trong MySQL bằng kỹ thuật sử dụng lệnh LIMIT.

Như bạn biết, thật dễ dàng để lấy dữ liệu mới nhất hoặc cũ nhất bằng cách sử dụng lệnh order by và limit. Nhưng đôi khi bạn muốn lấy record thứ x trong kết quả trả về thì làm thế nào? Chúng ta cùng tìm hiẻu ngay nhé.

Đầu tiên bạn cần viết câu truy vấn lấy danh sách kết quả trả về. Tuy thuộc vào nhu cầu mà bạn thiết lập sắp xếp tăng hay giảm dần.

Tiếp theo sử dụng lệnh LIMIT trong MySQL để lấy thứ tự của record mong muốn.

SELECT 
    *
FROM
    table_name
ORDER BY column_name DESC
LIMIT n - 1, 1;

Nếu bạn muốn lấy record thứ 5 thì n = 5.

Với cách này bạn có thể lấy record thứ bao nhiêu cũng được. Tuy nhiên kết tổng số record trả về của câu truy vấn bé hơn n thì bạn sẽ không thu được gì.

Bùi Văn Nam

27 chủ đề

7090 bài viết

Cùng chủ đề
0