zoukankan      html  css  js  c++  java
  • 将表中的某个字段转换成标识字段,并保留原来的值

    /*--将表中的某个字段转换成标识字段,并保留原来的值 
    
    注意,因为要删除原表,所以,如果表和其他表的关联,这些关联要重新创建 
    
    --邹建 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 表

  • 相关阅读:
    hibernate4.3.5,Final hibernate.cfg.xml的配置
    mysql 入门 jdbc
    设计模式之责任链
    淘宝技术这十年
    java代码---------计算器实现
    java代码---------打印正三角形
    java代码=====实现修改while()
    java------------break;
    java代码-----循环变量的
    java代码----------实现写出循环
  • 原文地址:https://www.cnblogs.com/rsls/p/4364109.html
Copyright © 2011-2022 走看看