很多查詢類的存儲過程會返回一個表結(jié)構(gòu)的結(jié)果集,如果在其他存儲過程中需要用到這個結(jié)果集,為了避免編寫重復(fù)的sql腳本,可以直接使用前者的查詢結(jié)果。
如,存儲過程sp_GetBorrowRecord @BeginTime,@EndTime 可以查詢出某一時間范圍(開始時間@BeginTime,結(jié)束時間@EndTime)內(nèi)的所有借書記錄。這個存儲過程可以用于對借書記錄的查詢頁面。
現(xiàn)在需要實(shí)現(xiàn)另一個功能:將某時間段內(nèi)的借書記錄進(jìn)行匯總分析。如按被借閱的書籍類型進(jìn)行分組,并按各類書籍的借書總數(shù)進(jìn)行排序。當(dāng)然可以直接使用group by等方法直接重新進(jìn)行查詢,但為了說明本例,暫且用另一種方法進(jìn)行實(shí)現(xiàn),并且該方法也有其特有的優(yōu)勢(在文章最后會提到)。如下所示,建一個新的存儲過程:
--獲取這段時間內(nèi)的借書記錄,并存入@Record表變量中
insert into @Record
exec sp_GetBorrowRecord @BeginTime,@EndTime
--接下來,就可以像使用一個普通的表一樣,對查出的數(shù)據(jù)(@Record中的數(shù)據(jù))進(jìn)行所需要的各項處理
--。。。。。
go
注:需要在sql server2005或更高版本中使用,低版本的sql server不支持該方法。
標(biāo)簽:呼和浩特 江蘇 新鄉(xiāng) 貴州 重慶 上海 拉薩 昭通
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《分享:在存儲過程中使用另一個存儲過程返回的查詢結(jié)果集的方法》,本文關(guān)鍵詞 分享,在,存儲,過程中,使用,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。