我正在使用Microsoft SQL Server 2014.在我们的要求中,自定义格式化的序列号是包含的。
序列号格式为 CAT-YYYY-MM-NNNNNN
。样本数据:
CAT-2016-10-000001
CAT-2016-10-000002
.
.
.
CAT-2016-10-999999
我不想使用 GUID 或其他任何内容,我想使用某个程序或功能。
所以,我正在尝试这个:
CREATE TABLE [category]
(
[id] int NOT NULL UNIQUE IDENTITY,
[category_no] nvarchar(20) NOT NULL,
[category_name] nvarchar(50) NOT NULL,
PRIMARY KEY ([id])
);
CREATE FUNCTION generate_category_no()
RETURNS CHAR(20)
AS
BEGIN
DECLARE @category_no CHAR(20)
SET @category_no = (SELECT MAX(category_no) FROM category)
IF @category_no IS NULL
SET @category_no = 'CAT-' + YEAR(getDate()) + '-' + MONTH(getDate()) + '-000001'
DECLARE @no int
SET @no = RIGHT(@category_no,6) + 1
RETURN 'CAT-' + YEAR(getDate()) + '-' + MONTH(getDate()) + '-' + right('00000' + CONVERT(VARCHAR(10),@no),6)
END
GO
ALTER TABLE category DROP COLUMN category_no;
ALTER TABLE category ADD category_no AS dbo.generate_category_no();
INSERT INTO category (category_name)
VALUES ('BMW'), ('JAGUAR');
当我逐步运行上面的SQL时,没关系。它没有显示任何错误。但是当我运行以下命令时:
SELECT * FROM category;
它显示以下错误:
Msg 217,Level 16,State 1,Line 1
超出了最大存储过程,函数,触发器或视图嵌套级别(限制32)。
我不知道如何解决这个问题。甚至我也不知道我的功能是否奏效。我从互联网上引用了这个功能。
ADDED
我需要每个月重置序列号。例如。对于下个月,不应该如下:
CAT-2016-11-000001
拜托,赐教。提前谢谢!
答案 0 :(得分:2)
修改您的功能如下
ALTER TABLE category DROP COLUMN category_no;
alter FUNCTION dbo.generate_category_no( @id int)
RETURNS CHAR(20)
AS
BEGIN
RETURN 'CAT-' + cast(YEAR(getDate()) as varchar(10)) + '-' + cast(MONTH(getDate()) as varchar(10))+ '-' + right('00000' + CONVERT(VARCHAR(10),@id),6)
END
ALTER TABLE category ADD category_no AS dbo.generate_category_no(id);
INSERT INTO category
(category_name)
VALUES
('BMW13'),
('JAGUAR');
SELECT * FROM category将给出以下结果。
1 BMW CAT-2016-10-000001
2 JAGUAR CAT-2016-10-000002
3 BMW1 CAT-2016-10-000003
4 BMW13 CAT-2016-10-000004
答案 1 :(得分:1)
试试这个:
初始化新字段:
ALTER TABLE category DROP COLUMN category_no;
ALTER TABLE category ADD category_no CHAR(20)
UPDATE category set category_no = dbo.generate_category_no()
对于其他插入:
CREATE TRIGGER [dbo].[category_i]
ON [dbo].[category]
AFTER INSERT
AS BEGIN
UPDATE category
SET category_no = dbo.generate_category_no()
FROM inserted
WHERE category.pk = inserted.pk
END
但您可以尝试使用SEQUENCE
功能,该功能在2012版本的Sql Server上可用
关于SEQUENCE
您可以看到here
答案 2 :(得分:1)
您的功能中最大的缺陷是它不适用于批量插入
由于您已自动生成ID
,因此这是一种更简单的方法
category_no AS Concat('CAT-', Year(Getdate()), '-', Month(Getdate()), '-', RIGHT(Concat('00000', id), 6))
<强>演示强>
CREATE TABLE #seq
(
id INT IDENTITY(1, 1),
name VARCHAR(10),
category_no AS Concat('CAT-', Year(Getdate()), '-', Month(Getdate()), '-', RIGHT(Concat('00000', id), 6))
)
INSERT INTO #seq
(name)
VALUES ('val')
结果:
id name category_no
-- ---- -----------
1 val CAT-2016-10-000001
答案 3 :(得分:0)
最后,我解决了这个问题。我的功能如下所示:
CREATE FUNCTION generate_category_no()
RETURNS CHAR(20)
AS
BEGIN
DECLARE @category_no CHAR(20)
SET @category_no = (SELECT MAX(category_no) FROM category WHERE category_no LIKE CONCAT('CAT-', YEAR(getDate()), '-', MONTH(getDate()), '-%'))
IF @category_no is null SET @category_no = CONCAT('CAT-', YEAR(getDate()), '-', MONTH(getDate()), '-000000')
DECLARE @no INT
SET @no = RIGHT(@category_no,6) + 1
RETURN CONCAT('CAT-', YEAR(getDate()), '-', MONTH(getDate()), '-', RIGHT('00000' + CONVERT(VARCHAR(10),@no),6))
END
GO
我插入数据如下:
INSERT INTO category (category_no, category_name) VALUES (dbo.generate_category_no(),'BMW');
INSERT INTO category (category_no, category_name) VALUES (dbo.generate_category_no(),'JAGUAR');
有一点是我们可以从INSERT查询中调用函数。
所以,当我运行以下sql时:
SELECT * FROM category;
它给出的结果如下所示。
+---+--------------------+--------------+
|id |category_no |category_name |
+---+--------------------+--------------+
| 1 |CAT-2016-10-000001 | BMW |
| 2 |CAT-2016-10-000002 | JAGUAR |
+---+--------------------+--------------+
感谢大家帮助我。感谢!!!