sql – 将现有列转换为Identity

我在sql Server中有一个包含记录包的表.我想将作为主键的ID列转换为标识列,而不会丢失数据.我想到了以下两种方法

>创建一个带有身份和放大器的新表删除现有表.
>使用标识和&创建一个新列删除现有列.

但很明显它们无法实施,因为保留记录是我的首要任务.

还有另一种方法吗?

解决方法

当您使用sql Server 2012时,另一种可能的替代方法是创建一个序列对象,该对象具有表中已有的最高ID 1的起始值,然后使用GET NEXT VALUE FOR为您的列创建认约束并引用您的序列刚刚创建的对象.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...