日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

如何在SQL Server查询语句(Select)中检索存储过程(Store Procedure)的结果集

發(fā)布時(shí)間:2023/12/18 数据库 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何在SQL Server查询语句(Select)中检索存储过程(Store Procedure)的结果集 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

如何在SQL?Server查詢語(yǔ)句(Select)中檢索存儲(chǔ)過(guò)程(Store?Procedure)的結(jié)果集?(2006-12-14 09:25:36)

與這個(gè)問(wèn)題具有相同性質(zhì)的其他描述還包括:
如何在SQL Server存儲(chǔ)過(guò)程中獲取另一存儲(chǔ)過(guò)程的執(zhí)行結(jié)果記錄集?
如何在存儲(chǔ)過(guò)程中檢索動(dòng)態(tài)SQL語(yǔ)句的執(zhí)行結(jié)果?
如何實(shí)現(xiàn)類似SELECT * FROM (EXEC procedure_name @parameters_var) AS datasource ... 的功能?procedure_name是一個(gè)存儲(chǔ)過(guò)程的名字,@parameters_var是過(guò)程參數(shù)列表
如何將一個(gè)存儲(chǔ)過(guò)程的執(zhí)行結(jié)果記錄集傳遞給另一個(gè)存儲(chǔ)過(guò)程?
存儲(chǔ)過(guò)程中如何根據(jù)另一個(gè)存儲(chǔ)過(guò)程的執(zhí)行結(jié)果選擇執(zhí)行流程?
存儲(chǔ)過(guò)程中如何根據(jù)動(dòng)態(tài)SQL語(yǔ)句的查詢結(jié)果更改執(zhí)行流程?
一個(gè)存儲(chǔ)過(guò)程A使用另一個(gè)存儲(chǔ)過(guò)程B的名字(或一段SQL語(yǔ)句或一個(gè)不確定的表名,字段名)作為參數(shù),如何在不改動(dòng)存儲(chǔ)過(guò)程B的情況下,對(duì)存儲(chǔ)過(guò)程B的執(zhí)行結(jié)果記錄集進(jìn)行過(guò)濾/更改,再將過(guò)濾/更改后的結(jié)果集返回給存儲(chǔ)過(guò)程A的調(diào)用者?

上面這些問(wèn)題都有一個(gè)共同點(diǎn),那就是都希望對(duì)存儲(chǔ)過(guò)程(或動(dòng)態(tài)SQL語(yǔ)句)的執(zhí)行結(jié)果進(jìn)行再處理,但是標(biāo)準(zhǔn)的SQL語(yǔ)句只能處理數(shù)據(jù)表,而一個(gè)存儲(chǔ)過(guò)程(或動(dòng)態(tài)SQL語(yǔ)句)的執(zhí)行結(jié)果雖然是記錄集,但它們本身不能當(dāng)做數(shù)據(jù)表來(lái)處理。這樣就大大限制了存儲(chǔ)過(guò)程(或動(dòng)態(tài)SQL語(yǔ)句)的應(yīng)用范圍,它們只能作為將記錄集返回給應(yīng)用程序前的最后一個(gè)處理層。如果我們可以像使用普通的數(shù)據(jù)表那樣使用存儲(chǔ)過(guò)程(或動(dòng)態(tài)SQL語(yǔ)句)該有多好。
這個(gè)問(wèn)題我以前的解決方法是使用OPENQUERY()或OPENDATASOURCE(),但OPENQUERY()不僅要求建立一個(gè)鏈接服務(wù)器,而且執(zhí)行性能也讓人無(wú)法滿意。OPENDATASOURCE()則要求提供連接字符串,這對(duì)系統(tǒng)后期的維護(hù)也是一個(gè)很大的麻煩。
今天使用SQL Server聯(lián)機(jī)叢書時(shí)無(wú)意中發(fā)現(xiàn)了一條SQL語(yǔ)句,竟然非常方便的解決了這個(gè)問(wèn)題。這個(gè)語(yǔ)句就是INSERT語(yǔ)句。
I(yíng)NSERT語(yǔ)句在幫助中的定義是這樣的: INSERT [ INTO]
??? { table_name WITH ( < table_hint_limited > [ ...n ] )
??????? | view_name
??????? | rowset_function_limited
??? } {??? [ ( column_list ) ]
??????? { VALUES
??????????? ( { DEFAULT | NULL | expression } [ ,...n] )
??????????? | derived_table
??????????? | execute_statement
??????? }
??? }
??? | DEFAULT VALUES 其中execute_statement的解釋是"任何有效的 EXECUTE 語(yǔ)句,它使用 SELECT 或 READTEXT 語(yǔ)句返回?cái)?shù)據(jù)。"。通常我們放在這個(gè)位置的就是一段SELECT語(yǔ)句。但幫助既然說(shuō)"任何有效的 EXECUTE 語(yǔ)句",那么"EXEC procedure_name"也應(yīng)該可以羅?想到這一點(diǎn),馬上決定動(dòng)手驗(yàn)證一下。驗(yàn)證結(jié)果證實(shí)沒問(wèn)題。即下面這樣的語(yǔ)句 INSERT INTO table_name EXEC procedure_name @parameters_value 確實(shí)可以正常工作。有了這個(gè)基礎(chǔ),我們也就有了解決本文開頭那些問(wèn)題的方法。 基本思路是先創(chuàng)建一個(gè)臨時(shí)表,通過(guò)INSERT ... EXEC ...語(yǔ)句將存儲(chǔ)過(guò)程的返回結(jié)果保存到臨時(shí)表中,接下來(lái)就可以像處理普通數(shù)據(jù)表那樣對(duì)待這個(gè)臨時(shí)表了。對(duì)于動(dòng)態(tài)SQL語(yǔ)句,可以通過(guò)dbo.sp_executesql存儲(chǔ)過(guò)程執(zhí)行,或者直接作為EXEC的參數(shù)執(zhí)行。具體的編寫要求可以參考SQL Server聯(lián)機(jī)叢書。這里只特別說(shuō)明一下,臨時(shí)表的表結(jié)構(gòu)與存儲(chǔ)過(guò)程(或動(dòng)態(tài)SQL語(yǔ)句)返回的記錄集的表結(jié)構(gòu)兼容即可,不要求完全相同。如果直接通過(guò)EXEC執(zhí)行動(dòng)態(tài)SQL語(yǔ)句,SQL語(yǔ)句有4K的長(zhǎng)度限制。
最后給出兩種最常見的處理流程:
1。創(chuàng)建一個(gè)臨時(shí)表#tmp,表結(jié)構(gòu)與目標(biāo)存儲(chǔ)過(guò)程procedure_name的返回結(jié)果集兼容(兼容即可,不必相同)。
??? CREATE TABLE #tmp(
??????? [columns_list]
??? )
2。執(zhí)行存儲(chǔ)過(guò)程并將存儲(chǔ)過(guò)程的返回結(jié)果集插入臨時(shí)表。
??? INSERT INTO #tmp EXEC procedure_name @parameters_var
3。現(xiàn)在可以使用(過(guò)濾,更改或檢索)#tmp了。^_^
??? IF EXISTS(SELECT * FROM #tmp)
??? BEGIN
??????? --執(zhí)行分支1
??? END ELSE BEGIN
??????? --執(zhí)行分支2
??? END 或者 SELECT * FROM #tmp WHERE ...
4。別忘了最后清除臨時(shí)表。
??? DROP TABLE #tmp 對(duì)于動(dòng)態(tài)SQL語(yǔ)句,只要將第二步改為
??? INSERT INTO #tmp EXEC dbo.sp_executesql @querystring_value
即可。

轉(zhuǎn)載于:https://www.cnblogs.com/zxh1141/archive/2013/02/16/2913609.html

總結(jié)

以上是生活随笔為你收集整理的如何在SQL Server查询语句(Select)中检索存储过程(Store Procedure)的结果集的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。