- [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] Tạo mã sản phẩm tự động như: SP0001, SP0002, SP0003... sử dụng Trigger
Xin chào các bạn, bài viết hôm nay mình hướng dẫn các bạn cách tạo mã sản phẩm tự động như product code: SP0001, SP0002... trong sqlserver.
[SQLSERVER] Tạo mã sản phẩm tự động Product Code: SP0001, SP0002,....
Đầu tiên, các bạn tạo cho mình 1 table Product
CREATE TABLE Product
(
ID INT IDENTITY(1,1) PRIMARY KEY,
Code VARCHAR(6),
Name NVARCHAR(50) NOT NULL
)
Video hướng dẫn step by step:
Tiếp đến, chúng ta sẽ tạo 1 Trigger, để khi dữ liệu insert mới vào chúng ta sẽ update cột Code lại.
CREATE TRIGGER trgAutoGenerateCode
ON Product
AFTER INSERT
AS
BEGIN
DECLARE @maxId INT, @newCode VARCHAR(10)
SELECT @maxId = ISNULL(MAX(RIGHT(Code, 4)), 0) + 1
FROM Product
SELECT @newCode = 'SP' + RIGHT('0000' + CAST(@maxId AS VARCHAR(4)), 4)
FROM Product
UPDATE Product SET Code = @newCode
WHERE Id IN (SELECT Id FROM inserted)
END
Giải thích các bước trong trigger:
- Bước 1: Tạo trigger với tên
trgAutoGenerateCode
cho bảngTableName
. - Bước 2: Trigger được kích hoạt sau khi một bản ghi mới được chèn vào bảng
TableName
. - Bước 3: Khai báo biến
@maxId
và@newCode
. - Bước 4: Lấy giá trị lớn nhất của mã code hiện có trong bảng, bỏ phần 'SP' và lấy 4 chữ số cuối cùng.
- Bước 5: Tạo mã code mới bằng cách cộng 1 vào giá trị
@maxId
, sau đó đưa nó về dạng chuỗi có 4 chữ số bằng cách sử dụng hàmRIGHT
và thêm phần 'SP' ở đầu. - Bước 6: Cập nhật mã code mới vào bảng cho tất cả các bản ghi mới được chèn, sử dụng điều kiện
WHERE Id IN (SELECT Id FROM inserted)
.
Tiếp đến, bạn insert vài sản phẩm để test thử.
INSERT INTO [dbo].[Product]
(
[Name]
)
VALUES
(
N'Beer' -- Name - nvarchar(50)
)
Và dưới đây là kết quả:
Thanks for watching!