Thứ Ba, 25 tháng 7, 2023

Hàm LAG trong SQL Server

Trong bài này mình sẽ hướng dẫn cách sử dụng hàm LAG trong SQL Server thông qua cú pháp và ví dụ thực tế.

Mục lục

  • 1. Mô tả
  • 2. Cú pháp
  • 3. Version
  • 4. Ví dụ

1. Mô tả

Hàm LAG là một hàm phân tích cho phép bạn truy vấn nhiều hàng trong một bảng mà không cần phải nối bảng với chính nó. Nó trả về các giá trị từ một hàng trước trong bảng.

2. Cú pháp

Cú pháp của hàm LAG trong SQL Server (Transact-SQL) là:

1
2
LAG ( expression [, offset [, default] ] )
OVER ( [ query_partition_clause ] order_by_clause )

Trong đó:

Bài viết này được đăng tại tranvanbinh.vn

  • expression: Một biểu thức có thể chứa các hàm dựng sẵn khác, nhưng không thể chứa bất kỳ hàm phân tích nào.
  • offset: Không bắt buộc. Nó là phần bù vật lý từ hàng hiện tại trong bảng. Nếu tham số này bị bỏ qua, mặc định là 1.
  • default: Không bắt buộc. Đó là giá trị được trả về nếu phần bù đi ra khỏi giới hạn của bảng. Nếu tham số này bị bỏ qua, mặc định là null.
  • query_partition_clause: Không bắt buộc. Nó được sử dụng để phân vùng kết quả thành các nhóm dựa trên một hoặc nhiều biểu thức.
  • order_by_clause: Không bắt buộc. Nó được sử dụng để sắp xếp dữ liệu trong mỗi phân vùng.

3. Version

Hàm LAG có thể được sử dụng trong các phiên bản sau của SQL Server (Transact-SQL):

  • SQL Server 2017, SQL Server 2016, SQL Server 2014, SQL Server 2012

4. Ví dụ

Nếu chúng ta có một bảng employees chứa dữ liệu sau:

employee_numberlast_namefirst_namesalary

dept_id

12009SutherlandBarbara5400045
34974YatesFred8000045
34987EricksonNeil4200045
45001ParkerSally5750030
75623GatesSteve6500030

Và chúng ta chạy câu lệnh SQL sau:

1
2
3
SELECT dept_id, last_name, salary,
LAG (salary,1) OVER (ORDER BY salary) AS lower_salary
FROM employees;

Nó sẽ trả về kết quả sau:

dept_id

last_namesalarylower_salary
45Erickson42000NULL
45Sutherland5400042000
30Parker5750054000
30Gates6500057500
45Yates8000065000

Trong ví dụ này, hàm LAG sẽ sắp xếp theo thứ tự tăng dần tất cả các giá trị salary trong bảng employees và sau đó trả về mức lương thấp hơn 1 vị trí trong tập kết quả do đã sử dụng offset là 1.

Nếu chúng ta sử dụng offset bằng 2 thay vào đó, nó sẽ trả lại mức lương thấp hơn 2 mức lương. Nếu sử dụng offset 3, thì nó sẽ trả lại mức lương thấp hơn 3 .... và cứ thế.

Sử dụng Partitions

Bây giờ hãy xem xét một ví dụ phức tạp hơn trong đó sử dụng mệnh đề truy vấn partition để trả lại mức lương thấp hơn cho mỗi nhân viên trong bộ phận của họ.

Nhập câu lệnh SQL sau:

1
2
3
SELECT dept_id, last_name, salary,
LAG (salary,1) OVER (PARTITION BY dept_id ORDER BY salary) AS lower_salary
FROM employees;

Nó sẽ trả về kết quả sau:

dept_id

last_name

salarylower_salary
30Parker57500NULL
30Gates6500057500
45Erickson42000NULL
45Sutherland5400042000
45Yates8000054000
=============================
* KHOÁ HỌC ORACLE DATABASE A-Z ENTERPRISE trực tiếp từ tôi giúp bạn bước đầu trở thành những chuyên gia DBA, đủ kinh nghiệm đi thi chứng chỉ OA/OCP, đặc biệt là rất nhiều kinh nghiệm, bí kíp thực chiến trên các hệ thống Core tại VN chỉ sau 1 khoá học.
* CÁCH ĐĂNG KÝ: Gõ (.) hoặc để lại số điện thoại hoặc inbox https://m.me/tranvanbinh.vn hoặc Hotline/Zalo 090.29.12.888
* Chi tiết tham khảo:
https://bit.ly/oaz_w
=============================
KẾT NỐI VỚI CHUYÊN GIA TRẦN VĂN BÌNH:
📧 Mail: binhoracle@gmail.com
☎️ Mobile/Zalo: 0902912888
👨 Facebook: https://www.facebook.com/BinhOracleMaster
👨 Inbox Messenger: https://m.me/101036604657441 (profile)
👨 Fanpage: https://www.facebook.com/tranvanbinh.vn
👨 Inbox Fanpage: https://m.me/tranvanbinh.vn
👨👩 Group FB: https://www.facebook.com/groups/DBAVietNam
👨 Website: https://www.tranvanbinh.vn
👨 Blogger: https://tranvanbinhmaster.blogspot.com
🎬 Youtube: https://www.youtube.com/@binhguru
👨 Tiktok: https://www.tiktok.com/@binhguru
👨 Linkin: https://www.linkedin.com/in/binhoracle
👨 Twitter: https://twitter.com/binhguru
👨 Podcast: https://www.podbean.com/pu/pbblog-eskre-5f82d6
👨 Địa chỉ: Tòa nhà Sun Square - 21 Lê Đức Thọ - Phường Mỹ Đình 1 - Quận Nam Từ Liêm - TP.Hà Nội

=============================
oracle tutorial, học oracle database, Tự học Oracle, Tài liệu Oracle 12c tiếng Việt, Hướng dẫn sử dụng Oracle Database, Oracle SQL cơ bản, Oracle SQL là gì, Khóa học Oracle Hà Nội, Học chứng chỉ Oracle ở đầu, Khóa học Oracle online,sql tutorial, khóa học pl/sql tutorial, học dba, học dba ở việt nam, khóa học dba, khóa học dba sql, tài liệu học dba oracle, Khóa học Oracle online, học oracle sql, học oracle ở đâu tphcm, học oracle bắt đầu từ đâu, học oracle ở hà nội, oracle database tutorial, oracle database 12c, oracle database là gì, oracle database 11g, oracle download, oracle database 19c, oracle dba tutorial, oracle tunning, sql tunning , oracle 12c, oracle multitenant, Container Databases (CDB), Pluggable Databases (PDB), oracle cloud, oracle security, oracle fga, audit_trail,oracle RAC, ASM, oracle dataguard, oracle goldengate, mview, oracle exadata, oracle oca, oracle ocp, oracle ocm , oracle weblogic, postgresql tutorial, mysql tutorial, mariadb tutorial, ms sql server tutorial, nosql, mongodb tutorial, oci, cloud, middleware tutorial, hoc solaris tutorial, hoc linux tutorial, hoc aix tutorial, unix tutorial, securecrt, xshell, mobaxterm, putty

ĐỌC NHIỀU

Trần Văn Bình - Oracle Database Master