我使用的是SQL Server2008 R2,我有一个架构[dbo],并且在该架构中,我创建了一个存储过程dbo.GetAccount
SELECT * FROM tblAccount然后,我已经创建了一个名为UserABC的用户的模式[ABC]。
现在,我想使用UserABC登录并对模式[ABC]执行dbo.GetAccount,以获取它的所有用户,并且不想更改dbo.GetAccount的代码。那么,我该怎么做呢?
谢谢你的帮助。
发布于 2014-08-20 18:14:34
如果我没记错的话,
SELECT * FROM tblAccount actualy means SELECT * FROM [dbo].[tblAccount] 因此,您的过程将始终从dbo模式执行tblAccount。
如果您想(比方说)有一个可以从更多模式执行“通用”过程,我建议您尝试使用动态sql。
CREATE PROCEDURE [dbo].[GetAccout]
@schema
as
declare @sql varchar(200)
set @sql = 'SELECT * FROM ['+@schema+'].[tblAccount]'
exec(@sql)然后运行exec [dbo].[GetAccout] ABC
这将选择来自YourSchema.tblAccount的所有信息。
我现在不能测试它,但我应该工作。还要记住,表必须在该模式中!
但是如果你不能改变所有的程序,我想不出一个解决方案。
https://stackoverflow.com/questions/25401919
复制相似问题