[SQLSERVER] Chia sẽ hàm tính tháng chính xác từ ngày đến ngày
Xin chào các bạn bài viết hôm nay, mình xin chia sẽ các bạn hàm funciton trong Sqlserver dùng để tính số tháng từ ngày đến ngày. Nếu bạn nào đang viết ứng dụng phần mềm nhân sự. Thường các bạn sẽ dính đến trường hợp sau: Ví dụ: Nhân viên A vào ...
Xin chào các bạn bài viết hôm nay, mình xin chia sẽ các bạn hàm funciton trong Sqlserver dùng để tính số tháng từ ngày đến ngày.
Nếu bạn nào đang viết ứng dụng phần mềm nhân sự.
Thường các bạn sẽ dính đến trường hợp sau:
Ví dụ:
Nhân viên A vào làm từ ngày 15/01/2019, thì khi nào đến ngày 15/02/2019 mới được tính là làm một tháng.
Chứ nếu đến ngày 14/02/2019 vẫn chưa được tính là một tháng.
Các bạn có thể sử dụng hàm này để tính thâm niên làm việc của nhân sự.
Trong giao diện Sqlserver Management Studio, các bạn tạo cho mình một hàm funcition với tên như sau fn_tinhthang_tungay_denngay.
Source code T-SQL fn_tinhthang_tungay_denngay:
SET QUOTED_IDENTIFIER ON SET ANSI_NULLS ON GO ALTER FUNCTION fn_tinhthang_tungay_denngay ( @DateA DATETIME, @DateB DATETIME ) RETURNS INT AS BEGIN DECLARE @Result INT DECLARE @DateX DATETIME DECLARE @DateY DATETIME IF(@DateA < @DateB) BEGIN SET @DateX = @DateA SET @DateY = @DateB END ELSE BEGIN SET @DateX = @DateB SET @DateY = @DateA END SET @Result = ( SELECT CASE WHEN DATEPART(DAY, @DateX) > DATEPART(DAY, @DateY) THEN DATEDIFF(MONTH, @DateX, @DateY) - 1 ELSE DATEDIFF(MONTH, @DateX, @DateY) END AS result ) RETURN @Result END GO
- Cách sử dụng hàm:
- Các bạn truyền thời gian, từ ngay đến ngày và hàm này sẽ trả về số tháng cho các bạn.
SELECT dbo.fn_tinhthang_tungay_denngay('20190115', '20190214') SELECT dbo.fn_tinhthang_tungay_denngay('20190115', '20190215')
Kết quả khi thực hiện truy vấn:
HAVE FUN :)