将表中的某个字段转换成标识字段,并保留原来的值
来源:互联网 发布:3d设计软件 编辑:程序博客网 时间:2024/05/22 06:39
/*--将表中的某个字段转换成标识字段,并保留原来的值 注意,因为要删除原表,所以,如果表和其他表的关联,这些关联要重新创建 --邹建 2003.12--*/ /*--调用示例 exec p_setid '表名','要转换的字段名' --*/ alter 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 表
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- 将表中的某个字段转换成标识字段,并保留原来的值
- oracle动态更新(将A表中的某个字段的值赋给B表中的某个字段)
- oracle将一个表中的某个字段的值,同步到另外一张表的某个字段中
- 将A表中某个字段的值赋给B表某个字段
- 将某个表的Code字段变成自动编号字段
- ASP.NET - SiteMapPath Web 服务器控件概述
- History命令用法
- bat批处理 for命令
- MySQL复制原理图解
- 因为数据库正在使用,所以无法获得对数据库的独占访问权---还原或删除数据库的解决方法
- 将表中的某个字段转换成标识字段,并保留原来的值
- 迷宫~哈哈~终于懂了。。
- 深入分析 Java I/O 的工作机制(网络 I/O 优化)
- vim中小写字母和大学字母的转换
- 我看TechEd 2012之App时代降临
- IOS中的编码格式—char*汉字转为NSString*
- UITableView 行自适应高度的实现
- /usr/bin/ld: cannot find -lGL
- GDI画sin曲线