- [SQLSERVER] Loại bỏ Restricted User trên database MSSQL
- [C#] Hướng dẫn tạo mã QRcode Style trên winform
- [C#] Hướng dẫn sử dụng temp mail service api trên winform
- [C#] Hướng dẫn tạo mã thanh toán VietQR Pay không sử dụng API trên winform
- [C#] Hướng Dẫn Tạo Windows Service Đơn Giản Bằng Topshelf
- [C#] Chia sẻ source code đọc dữ liệu từ Google Sheet trên winform
- [C#] Chia sẻ source code tạo mã QR MOMO đa năng Winform
- [C#] Chia sẻ source code phần mềm lên lịch tự động chạy ứng dụng Scheduler Task Winform
- [Phần mềm] Tải và cài đặt phần mềm Sublime Text 4180 full version
- [C#] Hướng dẫn download file từ Minio Server Winform
- [C#] Hướng dẫn đăng nhập zalo login sử dụng API v4 trên winform
- [SOFTWARE] Phần mềm gởi tin nhắn Zalo Marketing Pro giá rẻ mềm nhất thị trường
- [C#] Việt hóa Text Button trên MessageBox Dialog Winform
- [DEVEXPRESS] Chia sẻ code các tạo report in nhiều hóa đơn trên XtraReport C#
- [POWER AUTOMATE] Hướng dẫn gởi tin nhắn zalo từ file Excel - No code
- [C#] Chia sẻ code lock và unlock user trong domain Window
- [DEVEXPRESS] Vẽ Biểu Đồ Stock Chứng Khoán - Công Cụ Thiết Yếu Cho Nhà Đầu Tư trên Winform
- [C#] Hướng dẫn bảo mật ứng dụng 2FA (Multi-factor Authentication) trên Winform
- [C#] Hướng dẫn convert HTML code sang PDF File trên NetCore 7 Winform
- [C#] Hướng dẫn viết ứng dụng chat với Gemini AI Google Winform
[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 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 :)