将表中的某个字段转换成标识字段,并保留原来的值

原创 2004年02月15日 23:39:00

/*--将表中的某个字段转换成标识字段,并保留原来的值

 注意,因为要删除原表,所以,如果表和其他表的关联,这些关联要重新创建

--邹建 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]
GO

CREATE 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 表

将表中的某个字段转换成标识字段,并保留原来的值

/*--将表中的某个字段转换成标识字段,并保留原来的值 注意,因为要删除原表,所以,如果表和其他表的关联,这些关联要重新创建 --邹建 2003.12--*/ /*--调用示例 exe...
  • ren8179
  • ren8179
  • 2012年12月27日 11:14
  • 301

使用BeanUtils.describe将对象转换成Map时,数组字段的值只获取到第一个元素

情景:在开发过程中,需要将两个对象实体的值进行对比 处理:使用BeanUtils.describe将两个对象转换成Map进行遍历对比数据 问题:发现BeanUtils.describe转换后的Map的...

关于解决对象空值转换成JSON丢失字段的问题

这个是最近刚开发的迭代中遇到的问题频繁的转换JSON  结果导致空值字段丢失   但是对于前端来说即使字段值为空也需要返回所以这个时候就需要做处理  我是用的是  import com.alibaba...

php如何将图片gif,jpg或mysql longblob或blob字段值转换成16进制字符串

php如何将图片gif,jpg或mysql longblob或blob字段值转换成16进制字符串!经过查找居然如此简单,一个函数就搞定了。   数据库脚本: -- ---------------...
  • ljl_xyf
  • ljl_xyf
  • 2011年08月17日 16:59
  • 1057

SQL_把表中字段存储的逗号隔开内容转换成列表形式

我们日常开发中,不管是表设计问题抑或是其他什么原因,或多或少都会遇到一张表中有一个字段存储的内容是用逗号隔开的列表。   具体效果如下图:   ------》      从左边图转换成右边图,像...

long类型字段转换成varchar2类型

参考文档: How to Convert a Long to Varchar2 (文档 ID 228532.1) /*long类型字段转换成varchar2类型*/ --建表 create table...

java多线程,将oracle中数据导入到sql到文件(包括大字段转换成字符串)

import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.Fi...

将Oracle中Blob字段存储的图片转换成字节流直接输出到浏览器

具体代码如下: //  输出 blob  字段图片  (传入 blob 类型的 obj 对象) public static void outPutBlobImg(Object obj,HttpSer...

[Android] Gson高级用法:Json串转换成接口字段

工作后就很少更新博客,这两天在Json解析的时候遇到问题,空了正好记录下。问题 将后端获取数据转换成客户端创建的模型,然后转换成Json串存入数据库。当在无网络的情况下,则会从数据库从取出数...

SQLServer、Oracle获取数据库、表、表里字段、类型、主键、标识、注释

SQLServer、Oracle获取数据库、表、表里字段类型注释
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:将表中的某个字段转换成标识字段,并保留原来的值
举报原因:
原因补充:

(最多只允许输入30个字)