当前位置:  开发笔记 > 数据库 > 正文

SQL Server动态查询

如何解决《SQLServer动态查询》经验,为你挑选了1个好方法。

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

例:

Common: tblCommon
Specific: tblSpecific

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

SELECT ....
FROM tblCommon c
INNER JOIN @TABLE s on c.primaryKey = s.foreignKey

Peter M.. 11

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

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

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

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



1> Peter M..:

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

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

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

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

推荐阅读
爱唱歌的郭少文_
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有