如何在 T-SQL 表变量中重新植入标识列?

发布于 2024-07-05 23:33:40 字数 92 浏览 12 评论 0原文

我有一个 T-SQL 表变量(不是表),它有一个自动递增的标识列。 我想清除该变量中的所有数据并将标识列值重置为 1。如何做到这一点?

I have a T-SQL table variable (not a table) which has an auto incrementing identity column. I want to clear all data from this variable and reset the identity column value to 1. How can this be done?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

弄潮 2024-07-12 23:33:40

如果需要在 while 循环的每一轮中截断表变量,可以将 declare @myTbl (...) 语句放入循环中。 这将重新创建表并在循环的每一轮重置标识列。 然而,它对性能造成了严重影响。 我有相当紧的循环,并且重新声明相对于删除@myTbl的表变量要慢几倍。

If you need to truncate the table variable in each turn of a while loop, you can put the declare @myTbl (...) statement in the loop. This will recreate the table and reset the identity column on each turn of the loop. However, it has a heavy performance hit. I had fairly tight loop, and redeclaring the table variable relative to delete @myTbl was several times slower.

  • Dan
回忆追雨的时光 2024-07-12 23:33:40
    declare @tb table (recid int,lineof int identity(1,1))

    insert into @tb(recid)
    select recid from tabledata 

    delete from @tb where lineof>(select min(lineof) from @tb)+@maxlimit

当我想在使用 SQL 2000 时使用 TOP 和变量时,我就这样做了。基本上,您添加记录,然后查看最小记录。 我遇到了同样的问题并注意到了这个线程。 删除表不会重置种子,尽管我想象使用 GO 应该删除表和变量来重置种子。

上面查询中的 @maxlimit 是为了获取查询的前 900 个,并且由于表变量将具有不同的起始标识键,这将解决该问题。

任何后续查询都可以减去该派生过程以使其插入为“1”等。

    declare @tb table (recid int,lineof int identity(1,1))

    insert into @tb(recid)
    select recid from tabledata 

    delete from @tb where lineof>(select min(lineof) from @tb)+@maxlimit

I did this when I wanted to use a TOP and a variable when using SQL 2000. Basically, you add in the records and then look at the minimum one. I had the same problem and noticed this thread. Deleting the table doesn't reset the seed although I imagine using GO should drop the table and variable to reset the seed.

@maxlimit in the query above was to get the top 900 of the query and since the table variable would have a different starting identity key, this would solve that issue.

Any subsequent query can subtract that derived procedure to make it insert as "1", etc.

许久 2024-07-12 23:33:40

我建议您使用两个表变量。 @Table1 在第一列上有一个身份种子。 @Table2 具有相同的第一列,但其上没有身份种子。

当您循环处理流程时,

Insert into @Table2 from @Table1

请在流程循环时从两个表中删除。

在第一次通过时,@Table2 将在第一行中具有从 1 开始的序列号。

第二次循环时,您的第二个表可能在第一列中具有从 1081 开始的序列号。但是如果您选择最小值到一个变量

(Select @FixSeed = min(RowID) From @Table2)

然后你可以更新@Table2以使RowID从1开始,如下所示:

Update @Table2  Set  RowID = RowID - @FixSeed +1

希望这有帮助

I suggest you use two table variables. The @Table1 has an identity seed on the first column. @Table2 has the same first column but no identity seed on it.

As you loop through your process,

Insert into @Table2 from @Table1

then Delete From both Tables as your Process Loops.

On your first pass, the @Table2 will have a a sequential number in the first row starting at 1.

The second time through the loop your second table might have sequential numbers in the first column starting at say 1081. But if you select the minimum value to a variable

(Select @FixSeed = min(RowID) From @Table2)

Then you can update @Table2 to make RowID start at 1 as follows:

Update @Table2  Set  RowID = RowID - @FixSeed +1

Hope this helps

痴梦一场 2024-07-12 23:33:40

截断表将转储所有数据,并重置身份种子。

否则,您可以使用此调用来重置身份,同时保留任何数据:

DBCC CHECKIDENT (yourtableName, reseed, @NewStartSeedValue)

Truncating the table will dump ALL the data, and reset the identity seed.

Otherwise, you can use this call to reset the identity while retaining any of the data:

DBCC CHECKIDENT (yourtableName, reseed, @NewStartSeedValue)
浊酒尽余欢 2024-07-12 23:33:40

如果您使用的是表变量,则无法执行此操作。 如果它是一个表,您可以截断它或使用DBCC CHECKIDENT。 但是,如果您必须使用表变量,则必须使用标识列以外的其他内容。 或者,更准确地说,使用表变量中的标识列,但使用 ROWNUMBER 进行输出:

DECLARE @t table (pkint int IDENTITY(1,1), somevalue nvarchar(50))
INSERT INTO @t (somevalue) VALUES( 'one')
INSERT INTO @t (somevalue) VALUES('twp')
INSERT INTO @t (somevalue) VALUES('three')
SELECT row_number() OVER (ORDER BY pkint), somevalue FROM @t
DELETE FROM @t
INSERT INTO @t (somevalue) VALUES('four')
SELECT row_number() OVER (ORDER BY pkint), somevalue FROM @t

这是您可以对表变量执行的最佳操作。

If you're using a table variable, you can't do it. If it were a table, you could truncate it or use DBCC CHECKIDENT. But, if you have to use a table variable, you have to use something other than an identity column. Or, more accurately, use the identity column in your table variable but output using ROWNUMBER:

DECLARE @t table (pkint int IDENTITY(1,1), somevalue nvarchar(50))
INSERT INTO @t (somevalue) VALUES( 'one')
INSERT INTO @t (somevalue) VALUES('twp')
INSERT INTO @t (somevalue) VALUES('three')
SELECT row_number() OVER (ORDER BY pkint), somevalue FROM @t
DELETE FROM @t
INSERT INTO @t (somevalue) VALUES('four')
SELECT row_number() OVER (ORDER BY pkint), somevalue FROM @t

It's the best you can do with the table variable.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文