NEWS
- [TOOL] Chia sẻ phần mềm thay đổi thông tin cấu hình máy tính
- [C#] Hướng dẫn Export dữ liệu ra file Microsoft Word Template
- [C#] Chia sẻ source code tool kiểm tra domain website
- [C#] Hướng dẫn tạo file PDF sử dụng thư viện QuestPDF
- [C#] Hướng dẫn tạo ứng dụng dock windows giống Taskbar
- [C#] Chia sẻ source code sử dụng Object Listview trên Winform
- [VB.NET] Chia sẻ source code quản lý thu chi mô hình 3 lớp Winform
- [DATABASE] Xóa lịch sử danh sách đăng nhập tài khoản trên SMSS Sqlserver Management Studio
- [C#] Sử dụng FolderBrowserDialog Vista trên Winform
- [DEVEXPRESS] Chia sẻ tool Winform UI Templates Early Access Preview (EAP)
- [C#] Chia sẻ source code Spin Content (Trộn nội dung văn bản theo từ đồng nghĩa) trên Winform
- [VB.NET] Chia sẻ source code lịch âm dương và hẹn lịch nhắc việc
- [C#] Hướng dẫn đọc thông số thiết bị Thiết bị kiểm tra Pin (HIOKI BATTERY HiTESTER BT3562)
- [VB.NET] Hướng dẫn giải captcha sử dụng dịch vụ AZCaptcha API trên winform
- [C#] Hướng dẫn chứng thực đăng nhập ứng dụng bằng vân tay (Finger Print) trên máy tính
- [C#] Color Thief cách xuất màu sắc thiết kế từ hình ảnh
- [C#] Cách tạo bản quyền và cho phép dùng thử ứng dụng Winform
- [C#] Hướng dẫn sử dụng trình duyệt web Chrome convert HTML sang tập tin file PDF
- [C#] Kết nôi điện thoại Android, IOS với App Winform via Bluetooth
- [DATABASE] Cách query cộng trừ dồn dần trong Sqlserver
[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!