- [C#] Ẩn ứng dụng winform từ Apps vào Background Process trên Task Manager
- [SQLSERVER] Xử lý ngoại lệ sử dụng TRY...CATCH và RAISEERROR
- [C#] Bắt sự kiện bàn phím chuột bên ngoài ứng dụng winform sử dụng thư viện MouseKeyHook
- [DEVEXPRESS] Đặt mật khẩu và bỏ mật khẩu tập tin file PDF
- [C#] Thêm ứng dụng vào Taskbar sử dụng SharpShell DeskBand
- [C#] Hướng dẫn thêm text vào hình ảnh icon winform
- [C#] Chia sẽ tổng hợp source code đồ án về Csharp
- [C#] Hướng dẫn viết ứng dụng quay màn hình video winform, Screen Recorder
- [C#] Hướng dẫn sử dụng thư viện Input Simulator để làm việc với Keyboard, Mouse Virtual
- [DEVEXPRESS] Hướng dẫn tích Filter Contain khi click chuột phải vào cell selection trên Gridview
- [C#] Tra cứu mã số thuế cá nhân bằng CMND hoặc CCCD
- [C#] Convert hình ảnh image thành Blurhash sử dụng trong loading image winform
- [POWERSHELL] Script sao lưu backup và nén database sqlserver
- [C#] Giới thiệu thư viện Autofac Dependency Injection
- [C#] Hướng dẫn tạo Windows Services đơn giản Winform
- [C#] Một click chuột điều khiển máy tính từ xa sử dụng Ultraviewer
- Hướng dẫn đóng gói phần mềm sử dụng Powershell biên dịch script thành file exe
- [C#] Hướng dẫn sử dụng Task Dialog trên NET 5
- [C#] Hướng dẫn xem lịch sử các trang web đã truy cập trên Chrome Browser
- [C#] Hướng dẫn lấy thông tin Your ID và Password của Ultraviewer 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 :)