IT猫扑网:您身边最放心的安全下载站! 最新更新|软件分类|软件专题|手机版|论坛转贴|软件发布

您当前所在位置:首页数据库MSSQL → 重命名Sql Server外键约束名的方法

重命名Sql Server外键约束名的方法

时间:2015/6/28来源:IT猫扑网作者:网管联盟我要评论(0)

数据库原先是采用PowerDesigner设计的,sql server外键约束的命名非常难看,并且也和后来在SSMS中额外添加的Sql Server外键约束命名规则不一致,因此想遍历数据库的所有外键约束,找到外键约束的相关对象,然后重新生成一致的命名。

采用的命名规则是:

  1. FK_ForeignTable_PrimaryTable_On_ForeignColumn 

直白的翻译就是,ForeignTable在ForeignColumn列上引用了PrimaryTable的主键。

Sql Server提供了很多动态管理视图(Dynamic management views,DMV)和存储过程,方便我们对数据库进行维护。这里我用到了以下两个sys.foreign_key_columns(包含外键约束完整信息)和sys.objects(数据库对象信息)这两个DMV以及sp_rename执行重命名的系统存储过程。代码如下:

  1. declare fkcur cursor for  
  2. select  
  3. OBJECT_NAME(col.constraint_object_id) as FKConstraintName  
  4. ,fkTable.name as FKTable  
  5. ,fkCol.name as FKColumn  
  6. ,pkTable.name as PKTable  
  7. ,pkCol.name as PKColumn  
  8. from sys.foreign_key_columns col  
  9. -- 外键约束是建立在外键表上的,  
  10. -- 因此foreign_key_columns表中的parent_object_id和parent_column_id分别表示外键表和外键列  
  11. inner join sys.objects fkTable  
  12.     on fkTable.object_id = col.parent_object_id  
  13. inner join sys.columns fkCol  
  14.     on fkCol.column_id = col.parent_column_id  
  15.     and fkCol.object_id = fkTable.object_id  
  16. -- foreign_key_columns表中的referenced_object_id和referenced_column_id分别指向  
  17. -- 外键约束的主键表对象以及主键列  
  18. inner join sys.objects pkTable  
  19.     on pkTable.object_id = col.referenced_object_id  
  20. inner join sys.columns pkCol  
  21.     on pkCol.column_id = col.referenced_column_id  
  22.     and pkCol.object_id = pkTable.object_id  
  23. order by OBJECT_NAME(col.constraint_object_id)  
  24.  
  25. open fkcur  
  26. declare @constraintName nvarchar(128)  
  27. declare @fkTable nvarchar(64)  
  28. declare @fkColumn nvarchar(64)  
  29. declare @pkTable nvarchar(64)  
  30. declare @pkColumn nvarchar(64)  
  31. declare @newConstraintName nvarchar(128)  
  32.  
  33. fetch next from fkcur  
  34. into @constraintName,@fkTable,@fkColumn,@pkTable,@pkColumn  
  35. while @@FETCH_STATUS = 0 
  36. begin  
  37.     set @newConstraintName = 'FK_'+@fkTable+'_'+@pkTable+'_On_'+@fkColumn  
  38.     exec sp_rename @constraintName,@newConstraintName,'Object'  
  39.  
  40.     fetch next from fkcur  
  41.     into @constraintName,@fkTable,@fkColumn,@pkTable,@pkColumn  
  42. end  
  43. close fkcur  
  44. deallocate fkcur  

关键词标签:Sql Server

相关阅读

文章评论
发表评论

热门文章 SqlServer2005对现有数据进行分区具体步骤SqlServer2005对现有数据进行分区具体步骤sql server系统表损坏的解决方法sql server系统表损坏的解决方法MS-SQL2005服务器登录名、角色、数据库用户MS-SQL2005服务器登录名、角色、数据库用户Access、SQL Server、Oracle常见应用的区别Access、SQL Server、Oracle常见应用的区别

相关下载

人气排行 如何远程备份(还原)SQL2000数据库SQL2000数据库远程导入(导出)数据配置和注册ODBC数据源-odbc数据源配置教程SQL2000和SQL2005数据库服务端口查看或修改SQL Server 2005降级到2000的正确操作步骤修改Sql Server唯一约束教程浅谈JSP JDBC来连接SQL Server 2005的方法SQL Server创建表语句介绍