当前位置:  开发笔记 > 数据库 > 正文

如何在不插入表的情况下增加(或保留)SQL Server中的IDENTITY值

如何解决《如何在不插入表的情况下增加(或保留)SQLServer中的IDENTITY值》经验,为你挑选了1个好方法。

有没有办法保留或跳过或增加标识列的值?

我有两张桌子加在一对一的关系中.第一个有IDENTITY PK列,第二个有PK(不是IDENTITY).我以前插入,获取ID并插入第二个.它工作正常.

现在我需要在第二个表中插入值而不插入第一个.

现在,如何增加IDENTITY种子,所以我可以将它插入到第二个表中,但在第一个表的ID中留下"空洞"?

编辑:更多信息

这有效:

-- I need new seed number, but not table row 
-- so i will insert foo row, get id, and delete it
INSERT INTO TABLE1 (SomeRequiredField) VALUES ('foo'); 
SET @NewID = SCOPE_IDENTITY(); 
DELETE FROM TABLE1 WHERE ID=@NewID;

-- Then I can insert in TABLE2  
INSERT INTO (ID, Field, Field) VALUES (@NewID, 'Value', 'Value'); 

再次 - 这是有效的.

问题是我可以在不插入表的情况下获取ID吗?

DBCC需要所有者权利; 是否有一个干净的用户可调用SQL来做到这一点?



1> Mitchel Sell..:

这种情况会使您的整体数据结构难以理解.如果值之间没有关系,那么打破关系.

有办法绕过这个来做你正在寻找的东西,但通常它是在分布式环境中而不是因为似乎是数据模型的变化.

推荐阅读
虎仔球妈_459
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有