iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >sqlserver 批量修改数据库表主键名称为PK_表名
  • 157
分享到

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

sqlserver批量修改数据库表主键名称为PK_表名 2017-07-05 21:07:05 157人浏览 才女
摘要

我们在创建sqlserver得数据表的主键的时候,有时会出现,后面加一串随机字符串的情况,如图所示:    2.如果你有强迫症的话,可以使用以下sql脚本进行修改,将主键的名称修改为PK_表名. --将表的主键名统一规范为PK

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

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

 

 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

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

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

您可能感兴趣的文档:

--结束END--

本文标题: sqlserver 批量修改数据库表主键名称为PK_表名

本文链接: https://www.lsjlt.com/news/3637.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作