微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQL Server-SQL比较-自动识别和替换不同的数据库名称?

如何解决SQL Server-SQL比较-自动识别和替换不同的数据库名称?

| 我在本地有两个开发数据库
Alpha
Beta_Dev
我有两个远程生产数据库
Alpha
Beta
我使用sql Compare来同步两个Alpha数据库的架构。 有时,数据库in3ѭ的开发版本的数据库
Alpha
参考表中的存储过程或本地环境
Beta_Dev
中的存储过程。 例如:
Select * from Beta_Dev.dbo.MyTable
代码在生产服务器上不起作用,因为Beta数据库称为
Beta
,而不是
Beta_Dev
。 有没有一种方法可以使用sql Compare将所有SP或View进行比较,例如“ 10”? 当只有Beta_Dev / Beta不同时,不仅可以按工作顺序上传数据库,而且sql比较也不会被欺骗以为SP不同。     

解决方法

        我认为您无法按照自己想要的方式进行操作,但是如果适合您想要的操作,这是一种潜在的解决方法 为
Beta
数据库中引用的对象创建
Synonyms
USE [Alpha]
CREATE SYNONYM [dbo].[BetaMyTable] FOR [Beta].[dbo].[MyTable]
USE [Alpha_dev]
CREATE SYNONYM [dbo].[BetaMyTable] FOR [Beta_dev].[dbo].[MyTable]
因此您的proc现在可以使用:
SELECT * FROM BetaMyTable
在SQL Compare中,ѭ16中有一个忽略规则选项,称为
Database and server name in synonyms
。我相信默认情况下会选中它,但是如果您要更改它     

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