如何在SQLServer查询语句(Select)中检索存储过程(StoreProcedure)的结果

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

如何在SQLServer查询语句(Select)中检索存储过程(StoreProcedure)的结果集?与这个问题具有相同性质的其他描述还包括:如何在SQLServer存储过程中获取另一存储过程的执行结果记录集?如何在存储过程中检索动态SQL语句的执行结果?如何实现类似SELECT*FROM(EXECprocedure_name@parameters_var)ASdatasource...的功能?procedure_name是一个存储过程的名字,@parameters_var是过程参数列表如何将一个存储过程的执行结果记录集传递给另一个存储过程?存储过程中如何根据另一个存储过程的执行结果选择执行流程?存储过程中如何根据动态SQL语句的查询结果更改执行流程?一个存储过程A使用另一个存储过程B的名字(或一段SQL语句或一个不确定的表名,字段名)作为参数,如何在不改动存储过程B的情况下,对存储过程B的执行结果记录集进行过滤/更改,再将过滤/更改后的结果集返回给存储过程A的调用者?上面这些问题都有一个共同点,那就是都希望对存储过程(或动态SQL语句)的执行结果进行再处理,但是标准的SQL语句只能处理数据表,而一个存储过程(或动态SQL语句)的执行结果虽然是记录集,但它们本身不能当做数据表来处理。这样就大大限制了存储过程(或动态SQL语句)的应用范围,它们只能作为将记录集返回给应用程序前的最后一个处理层。如果我们可以像使用普通的数据表那样使用存储过程(或动态SQL语句)该有多好。这个问题我以前的解决方法是使用OPENQUERY()或OPENDATASOURCE(),但OPENQUERY()不仅要求建立一个链接服务器,而且执行性能也让人无法满意。OPENDATASOURCE()则要求提供连接字符串,这对系统后期的维护也是一个很大的麻烦。今天使用SQLServer联机丛书时无意中发现了一条SQL语句,竟然非常方便的解决了这个问题。这个语句就是INSERT语句。语句在帮助中的定义是这样的:INSERT[INTO]{table_nameWITH(table_hint_limited[...n])|view_name|rowset_function_limited}{[(column_list)]{VALUES({DEFAULT|NULL|expression}[,...n])|derived_table|execute_statement}}|DEFAULTVALUES其中execute_statement的解释是任何有效的EXECUTE语句,它使用SELECT或READTEXT语句返回数据。。通常我们放在这个位置的就是一段SELECT语句。但帮助既然说任何有效的EXECUTE语句,那么EXECprocedure_name也应该可以罗?想到这一点,马上决定动手验证一下。验证结果证实没问题。即下面这样的语句INSERTINTOtable_nameEXECprocedure_name@parameters_value确实可以正常工作。有了这个基础,我们也就有了解决本文开头那些问题的方法。基本思路是先创建一个临时表,通过INSERT...EXEC...语句将存储过程的返回结果保存到临时表中,接下来就可以像处理普通数据表那样对待这个临时表了。对于动态SQL语句,可以通过dbo.sp_executesql存储过程执行,或者直接作为EXEC的参数执行。具体的编写要求可以参考SQLServer联机丛书。这里只特别说明一下,临时表的表结构与存储过程(或动态SQL语句)返回的记录集的表结构兼容即可,不要求完全相同。如果直接通过EXEC执行动态SQL语句,SQL语句有4K的长度限制。最后给出两种最常见的处理流程:1。创建一个临时表#tmp,表结构与目标存储过程procedure_name的返回结果集兼容(兼容即可,不必相同)。CREATETABLE#tmp([columns_list])2。执行存储过程并将存储过程的返回结果集插入临时表。INSERTINTO#tmpEXECprocedure_name@parameters_var3。现在可以使用(过滤,更改或检索)#tmp了。^_^IFEXISTS(SELECT*FROM#tmp)BEGIN--执行分支1ENDELSEBEGIN--执行分支2END或者SELECT*FROM#tmpWHERE...4。别忘了最后清除临时表。DROPTABLE#tmp对于动态SQL语句,只要将第二步改为INSERTINTO#tmpEXECdbo.sp_executesql@querystring_value即可。更详细内容参考SQLServer联机丛书INSERT:INSERT(已描述)

1 / 2
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功