具体来说,我可以从视图中的当前数据库调用 proc 。我已经知道openrowset hack,所以这很有效,例如:
create view MyView as
select *
from openrowset (
'sqloledb',
'server=(local);trusted_connection=yes;',
'exec MyDatabase.dbo.MyStoredProcedure' -- Works fine
)
但我希望能够从当前数据库调用 proc,而无需像这样对名称进行硬编码:
create view MyView as
select *
from openrowset (
'sqloledb',
'server=(local);trusted_connection=yes;',
'exec ' + db_name() + '.dbo.MyStoredProcedure' -- Don't want to hard-code DB name
)
不幸的是,这不起作用,因为 openrowset 需要文字字符串,而不是任何类型的变量。
不考虑安全性和性能方面的考虑,是否有解决方法?这将使遗留系统的维护更加容易忍受,因为此视图将调用的 proc 根据环境(开发、测试、产品)连接到不同的数据库。