sqlserver 批量修改数据库表主键名称为PK_表名

sqlserver 批量修改数据库表主键名称为PK_表名sqlserver 批量修改表的主键名称,批量修改数据表的名称

sqlserver 批量修改数据库表主键名称为PK_表名

1.我们在创建sqlserver得数据表的主键的时候,有时会出现,后面加一串随机字符串的情况,如图所示:

sqlserver 批量修改数据库表主键名称为PK_表名

 

 2.如果你有强迫症的话,可以使用以下sql脚本进行修改,将主键的名称修改为PK_表名.

--将表的主键名统一规范为PK_表名
  
DECLARE @PK_Name_Old varchar(100),@Table_Name varchar(100),@PK_Name_New varchar(100),@Col_Name varchar(100)
DECLARE Cursor_Update_Table_PK_Name CURSOR FOR

SELECT 
  a.name AS "tbl_name",
  e.name AS "col_name",
  b.name,
  "PK_"+a.name as "new_pk_name"
FROM sysobjects AS a          --对象表,结合a.xtype="U"条件,查用户表
 LEFT JOIN sysobjects AS b --对象表,结合b.xtype="PK"条件,查主键约束
  ON a.id=b.parent_obj
 LEFT JOIN sysindexes AS c --索引表,根据(主键)约束名称匹配,查对应字段索引
  ON a.id=c.id AND b.name=c.name
 LEFT JOIN sysindexkeys AS d --索引中对应键、列的表,根据索引匹配,查字段id
  ON a.id=d.id AND c.indid=d.indid
 LEFT JOIN syscolumns AS e --字段表,根据字段id匹配,查字段名称
  ON a.id=e.id AND d.colid=e.colid
WHERE a.xtype="U"
  AND b.xtype="PK"
  
OPEN Cursor_Update_Table_PK_Name
FETCH NEXT FROM Cursor_Update_Table_PK_Name INTO @Table_Name,@Col_Name,@PK_Name_Old,@PK_Name_New
WHILE @@FETCH_STATUS = 0
	BEGIN
		PRINT ""+@Table_Name
			-- 存在主键约束,则删除 
			--IF EXISTS(SELECT * FROM sysobjects WHERE name=@PK_Name_Old and xtype="PK")
			
			Exec("Alter TABLE "+@Table_Name+" Drop Constraint "+@PK_Name_Old)
			
			 -- 重新添加主键约束
			Exec("ALTER TABLE "+@Table_Name+" ADD CONSTRAINT "+@PK_Name_New+" PRIMARY KEY ("+@Col_Name+") ")
			
		FETCH NEXT FROM Cursor_Update_Table_PK_Name INTO @Table_Name,@Col_Name,@PK_Name_Old,@PK_Name_New
	END
CLOSE Cursor_Update_Table_PK_Name
DEALLOCATE Cursor_Update_Table_PK_Name

代码100分

  使用以上代码可以批量将表的主键名进行修改

3.你可以可以对以上脚本进行修改,比如批量给表的前面增加某个字符串,聪明的你肯定知道怎么做的。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10268.html

(0)
上一篇 2022-12-30 15:30
下一篇 2022-12-30 16:30

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注