sql-server – SQL Server跨数据库别名

前端之家收集整理的这篇文章主要介绍了sql-server – SQL Server跨数据库别名前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图理解如何使用别名来引用同一实例中的另一个数据库,而不必使用硬编码名称.

方案如下:

我有一个带有存储数据的数据db,一个审计数据库,用于保存所有更改.由于各种原因,我希望将审计数据保存在一个单独的数据库中,这不仅仅是因为它可能会变得非常大并且出于报告目的.

在数据db中,我不想通过硬编码名称引用它,而是使用别名,以便在不同的环境中,我不必更改名称和各种sp来引用新名称.

例如:

mydevdata
mydevaudit

如果mydevdata中存在sp,例如调用mydevaudit的sp,那么当我去测试db的名称mytestdata和mytestaudit时,我不想更改sp.同样,由于各种原因,数据库名称可以更改,更多地与空格和实例等有关.

所以如果我在mydevdata中有程序:

proc A
begin

insert into mydevaudit.table.abc(somecol)
select 1

end

当我去测试时,我不想改变程序来引用另一个名字,(假设发生了争论的缘故)

相反,我希望做的事情如下:

proc A
begin

insert into AUDITEBALIAS.table.abc(somecol)
select 1

end

我有兴趣了解如何做到这样的事情,以及职业和缺点.

此外,dymnamic sql不是一个选项.

在此先感谢您的帮助.

解决方法

您可以使用 synonyms
CREATE SYNONYM WholeTableAliasWithDBetc FOR TheDB.dbo.TheTable

这意味着本地数据库中的所有对象引用都是该数据库的本地对象,但隐藏其他数据库的同义词除外.

您还可以在审计DB中使用存储过程.有一个EXEC的第三种形式很少使用,您可以参数化存储的proc名称

DECLARE @module_name_var varchar(100)
SET @module_name_var = 'mydevaudit.dbo.AuditProc'
--   SET @module_name_var = 'whatever.dbo.AuditProc'
EXEC @module_name_var @p1,@p2,...

显然你可以改变module_name_var来使用你喜欢的任何数据库

原文链接:https://www.f2er.com/mssql/83083.html

猜你在找的MsSQL相关文章