gpt4 book ai didi

带有前导填充零的 SQL 标识

转载 作者:行者123 更新时间:2023-12-02 01:18:43 28 4
gpt4 key购买 nike

我已在表中将一列标记为“身份”

create table Identitytest(
number int identity(1,001) not null,
value varchar(500)
)

我需要将身份列递增为 001,002,003 等。

数据库显示它正在插入为 1,2,3 等。

如何做到这一点?

最佳答案

正如其他人已经正确指出的那样 - INT 永远不会有前导零 - 它只是保存值,仅此而已(这样就很好)。

如果您需要一些额外的格式,您可以随时向表中添加计算列,例如:

ALTER TABLE dbo.Identitytest
ADD DisplayNumber AS RIGHT('000' + CAST(number AS VARCHAR(3)) , 3) PERSISTED

这样,您的 INT IDENTITY 将用作 INT 并始终包含数值,而 DisplayNumber 包含 001, 002, ... 014, 015, .... . 等等 - 自动地,始终是最新的。

由于它是持久字段,因此它现在是表的一部分,您可以对其进行查询,甚至可以在其上放置索引以使查询更快:

SELECT value FROM dbo.IdentityTest WHERE DisplayNumber = '024'

当然,您可以在计算列的定义中使用几乎任何格式,因此您还可以添加前缀或其他内容:

ALTER TABLE dbo.Identitytest
ADD DisplayNumber
AS 'ABC-' + RIGHT('000' + CAST(number AS VARCHAR(3)) , 3) PERSISTED

因此,在本例中,您的 DisplayNumber 将为 ABC-001、ABC-002、... 等等。

您可以两全其美 - 您可以保留您的 INT IDENTITY(它是数字形式并由 SQL Server 自动增加),并且您可以以您喜欢的任何方式定义显示格式并随时可用。

关于带有前导填充零的 SQL 标识,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3429284/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com