SQL臨時(shí)表遞歸查詢子信息并返回記錄的代碼
更新時(shí)間:2012年08月02日 16:22:14 作者:
SQL臨時(shí)表遞歸查詢子信息并返回記錄的代碼,需要的朋友可以參考下
復(fù)制代碼 代碼如下:
declare @Q_ID uniqueidentifier
set @Q_ID = dbo.uf_GetParamValueByName(@Params,'@指標(biāo)ID');
declare @QAExp_ID char(36) --指標(biāo)屬性公式ID
set @QAExp_ID='3D2B8F3F-0B7E-46FD-9B33-050F846C2869'
declare @temp_qid table(QID char(36),ExpValue nvarchar(max)) --臨時(shí)表變量獲得指標(biāo)根ID
declare @QIDtemp char(36),@express nvarchar(4000)
declare @k int=2 --層次
declare @pattern nvarchar(2)='ID' --指標(biāo)公式拆分字段
declare @charidex int --指標(biāo)對(duì)應(yīng)的索引
if(@OPType = '根據(jù)指標(biāo)ID查找公式所有子指標(biāo)')
begin
create table #TempQuotaStruct --創(chuàng)建臨時(shí)表#TmpStruct
(
QID char(36), --創(chuàng)建一個(gè)ID用來存儲(chǔ)指標(biāo)ID
PID char(36), --用來存儲(chǔ)該指標(biāo)相關(guān)的iD
OrderValue int --層級(jí)關(guān)系
)
insert #TempQuotaStruct(QID,OrderValue)values(@Q_ID,1)
while EXISTS(select Q_ID from EOTS_QuotaAttributeValue where QA_ID=@QAExp_ID and Q_ID in (select QID from #TempQuotaStruct where OrderValue=@k-1) )
begin
insert into @temp_qid select Q_ID,QAV_Value from EOTS_QuotaAttributeValue whereQA_ID=@QAExp_IDand Q_ID in (select QID from #TempQuotaStruct whereOrderValue=@k-1)
WHILE EXISTS(select QID from @temp_qid)
begin
select top 1 @QIDtemp=QID, @express=ExpValue from @temp_qid
print @QIDtemp
set @express=rtrim(ltrim(@express))
set @charidex=charindex(@pattern,@express)
while @charidex>=1
begin
insert into #TempQuotaStruct(QID,PID,OrderValue)values(SUBSTRING(@express,@charidex+2,36),@QIDtemp,@k)
set @express=SUBSTRING(@express,@charidex+38,len(@express)-@charidex+37)
set @charidex=charindex(@pattern,@express)
end
delete from @temp_qid where QID = @QIDtemp
end
set @k=@k+1
end
select a.*,b.Q_Name, c.QAV_Value as Q_Formula from #TempQuotaStruct a,EOTS_Quota b,EOTS_QuotaAttributeValue c where a.QID=b.Q_ID and a.QID=c.Q_ID and c.QA_ID='3D2B8F3F-0B7E-46FD-9B33-050F846C2869'
此SQL是對(duì)標(biāo)模塊的臨時(shí)表查詢,他能查出一個(gè)指標(biāo)下面的多個(gè)子指標(biāo)的公式,并分層級(jí)顯示 @指標(biāo)ID=#*1*#;#*1*#08bea0aaf-0ed2-4c9b-8c20-8c5bd919db6f#*1*#
摘自EOTS 存儲(chǔ)過程up_eots_Get_QuotaStruct
臨時(shí)表循環(huán)的關(guān)鍵就是下面的語句, select top 1 from #Tep,用一個(gè)變量循環(huán)取值,然后刪除循環(huán)中的值
復(fù)制代碼 代碼如下:
insert into #Tep select optname,value,major_version from MSreplication_options
while Exists(select a from #Tep)
begin
select top 1 @tempa =a,@tempc =c from #Tep
delete #Tep where a=@tempa
end
相關(guān)文章
sqlserver中通過osql/ocmd批處理批量執(zhí)行sql文件的方法
上周在測(cè)試環(huán)境建了幾十張表,保存了.sql文件,準(zhǔn)備在正式環(huán)境重建的時(shí)候懶得一個(gè)個(gè)打開建了,做一在網(wǎng)上搜尋了一下,果然有簡單點(diǎn)的方法。2011-08-08SQL Server中的排名函數(shù)與分析函數(shù)詳解
本文詳細(xì)講解了SQL Server中的排名函數(shù)與分析函數(shù),文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05關(guān)于sql和mysql對(duì)于別名不能調(diào)用的一些理解
由于有部分語句別名不能調(diào)用原來是由于別名機(jī)制不同引起的,為了避免下次發(fā)生就整理了一下sql和mysql執(zhí)行順序發(fā)現(xiàn)內(nèi)部機(jī)制是一樣的,最大區(qū)別是在別名的引用上2013-11-11Sql學(xué)習(xí)第一天——SQL 將變量定義為Table類型(虛擬表)
sql語句中的變量時(shí)通常我們定義的都是像char,varchar,nvarchar之類的,接下來教大家實(shí)現(xiàn)讓變量作為一個(gè)像虛擬表一樣,感性的各位可以參考下哈2013-03-03REPLICATE 以指定的次數(shù)重復(fù)字符表達(dá)式
sql server以指定的次數(shù)重復(fù)字符表達(dá)式REPLICATE函數(shù):REPLICATE函數(shù)用于以指定的次數(shù)重復(fù)字符表達(dá)式。2010-06-06