SQL Server动态查询

2 sql t-sql sql-server dynamic

我有15个存储过程从公共表返回数据,然后将该表与特定表连接以检索库存.

例:

Common: tblCommon
Specific: tblSpecific
Run Code Online (Sandbox Code Playgroud)

有没有办法我可以将名称"tblSpecific"作为变量传递给单个存储过程,如下所示?

SELECT ....
FROM tblCommon c
INNER JOIN @TABLE s on c.primaryKey = s.foreignKey
Run Code Online (Sandbox Code Playgroud)

Pet*_*r M 11

执行此操作的方法是使用动态生成的SQL,该SQL通过sp_executesql()存储过程运行.

通常,将所需的表名传递给主过程,构建要执行的SQL的ncharvar字符串,并将其传递给sp_executesql.

动态SQL的诅咒和祝福是关于描述所有内部和外部的最佳页面.

最大的问题之一是,如果使用动态SQL,则调用存储过程的用户不仅必须具有该过程的执行权限,而且还必须具有访问基础表的权限.我给出的链接还描述了如何解决这个问题.