/*--将表中的某个字段转换成标识字段,并保留原来的值 注意,因为要删除原表,所以,如果表和其他表的关联,这些关联要重新创建--邹建 2003.12--*//*--调用示例 exec p_setid '表名','要转换的字段名' --*/if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_setid]') and OBJECTPROPERTY(id, N'IsProcedure') = 1) drop procedure [dbo].[p_setid] GOCREATE PROC P_SETID @tbname sysname, --要处理的表名 @fdname sysname --要转换为标识字段的字段名 as declare @s1 varchar(8000),@s2 varchar(8000),@tmptb sysname select @s1='',@s2='',@tmptb='[tmp_'+@tbname+'_bak]' select @s1=@s1+',['+name+']' +case name when @fdname then '=identity(bigint,1,1)' else '' end ,@s2=@s2+',['+name+']' from syscolumns where object_id(@tbname)=id select @s1=substring(@s1,2,8000),@s2=substring(@s2,2,8000) exec('select top 0 '+@s1+' into '+@tmptb+' from ['+@tbname+'] set identity_insert '+@tmptb+' on insert into '+@tmptb+'('+@s2+') select '+@s2+' from ['+@tbname+'] set identity_insert '+@tmptb+' off ') exec('drop table ['+@tbname+']') exec sp_rename @tmptb,@tbname go--使用测试--创建测试的表 create table 表(编号 bigint,姓名 varchar(10)) insert into 表 select 1,'张三' union all select 2,'李四' union all select 4,'王五' go--调用存储过程,将编号字段改为标识字段 exec p_setid '表','编号' go--显示处理结果 select * from 表--显示是否修改成功 select name from syscolumns where object_id('表')=id and status=0x80 go--删除测试 drop table 表
--或者,你也可以为你的表增加一个触发器来完成此功能.create trigger t_insert on 你的表 for insert as declare @id int select @id=isnull(max(id),0) from 你的表 update 你的表 set @id=@id+1,id=@id where id is null go
也可以在企业管理器中直接操作类型 int 将标识设置为"是" 种子 1
to j9988(j9988) 企业管理器中直接操作安全.是通过事务处理的.这句怎么说,能说的具体点吗?谢谢
--*/if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_setid]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[p_setid]
GOCREATE PROC P_SETID
@tbname sysname, --要处理的表名
@fdname sysname --要转换为标识字段的字段名
as
declare @s1 varchar(8000),@s2 varchar(8000),@tmptb sysname
select @s1='',@s2='',@tmptb='[tmp_'+@tbname+'_bak]'
select @s1=@s1+',['+name+']'
+case name when @fdname then '=identity(bigint,1,1)' else '' end
,@s2=@s2+',['+name+']'
from syscolumns where object_id(@tbname)=id
select @s1=substring(@s1,2,8000),@s2=substring(@s2,2,8000)
exec('select top 0 '+@s1+' into '+@tmptb+' from ['+@tbname+']
set identity_insert '+@tmptb+' on
insert into '+@tmptb+'('+@s2+') select '+@s2+' from ['+@tbname+']
set identity_insert '+@tmptb+' off
')
exec('drop table ['+@tbname+']')
exec sp_rename @tmptb,@tbname
go--使用测试--创建测试的表
create table 表(编号 bigint,姓名 varchar(10))
insert into 表
select 1,'张三'
union all select 2,'李四'
union all select 4,'王五'
go--调用存储过程,将编号字段改为标识字段
exec p_setid '表','编号'
go--显示处理结果
select * from 表--显示是否修改成功
select name from syscolumns
where object_id('表')=id and status=0x80
go--删除测试
drop table 表
企业管理器--右键你的表--设计表--选择id(你要修改的字段)--在字段属性中--将标识设置为"是"
for insert
as
declare @id int
select @id=isnull(max(id),0) from 你的表
update 你的表 set @id=@id+1,id=@id where id is null
go
将标识设置为"是"
种子 1
企业管理器中直接操作安全.是通过事务处理的.这句怎么说,能说的具体点吗?谢谢
"
先生成一个IDENTITY的新表,
再插入原数据.
删旧表
新表改名
"但这整个过程是通过事务处理的.如果那个环节不成功则回滚.
如果你不是常做这样的操作,通过企业管理器处理不是很简单吗?
我想这种操作不会象查询一样天天做吧.