一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Sql Server - SQL臨時表遞歸查詢子信息并返回記錄的代碼

SQL臨時表遞歸查詢子信息并返回記錄的代碼

2019-12-21 15:29MSSQL教程網 Sql Server

SQL臨時表遞歸查詢子信息并返回記錄的代碼,需要的朋友可以參考下

代碼如下:


declare @Q_ID uniqueidentifier 
set @Q_ID = dbo.uf_GetParamValueByName(@Params,'@指標ID'); 
declare @QAExp_ID char(36) --指標屬性公式ID 
set @QAExp_ID='3D2B8F3F-0B7E-46FD-9B33-050F846C2869' 
declare @temp_qid table(QID char(36),ExpValue nvarchar(max)) --臨時表變量獲得指標根ID 
declare @QIDtemp char(36),@express nvarchar(4000) 
declare @k int=2 --層次 
declare @pattern nvarchar(2)='ID' --指標公式拆分字段 
declare @charidex int --指標對應的索引 
if(@OPType = '根據指標ID查找公式所有子指標') 
begin 
create table #TempQuotaStruct --創建臨時表#TmpStruct 

QID char(36), --創建一個ID用來存儲指標ID 
PID char(36), --用來存儲該指標相關的iD 
OrderValue int --層級關系 

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是對標模塊的臨時表查詢,他能查出一個指標下面的多個子指標的公式,并分層級顯示 @指標ID=#*1*#;#*1*#08bea0aaf-0ed2-4c9b-8c20-8c5bd919db6f#*1*# 
摘自EOTS 存儲過程up_eots_Get_QuotaStruct 
臨時表循環的關鍵就是下面的語句, select top 1 from #Tep,用一個變量循環取值,然后刪除循環中的值 

復制代碼代碼如下:


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 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日日碰碰 | 亚洲国产成人久久99精品 | zzjj中国| 亚洲免费一 | 亚洲精品αv一区二区三区 亚洲精品91大神在线观看 | www.亚洲天堂 | 日韩国产欧美精品综合二区 | 午夜办公室在线观看高清电影 | 青草福利在线 | 欧美日韩国产一区二区三区在线观看 | 免费一级黄 | 欧产日产国产精品专区 | 3d蒂法受辱在线播放 | 麻豆天美精东果冻传媒在线 | 男人午夜剧场 | 小便japanesewctv| 欧美日韩中文字幕久久伊人 | 国产成人精品免费视频大全五级 | 久久亚洲网站 | 国内精品视频一区二区三区 | 五月天精品视频播放在线观看 | 精品无码久久久久久久动漫 | 精品国产爱久久 | 日韩一区二区三 | 韩国美女主播在线 | bl双性小说 | 大肥婆丰满大肥奶bbw肥 | 成人精品视频 成人影院 | 国产国拍亚洲精品av | 青青操在线播放 | 暖暖暖免费观看在线观看 | 欧美又硬又粗又长又大 | 国产盗摄女厕美女嘘嘘 | 国产精品国产高清国产专区 | 国产亚洲人成网站在线观看不卡 | 欧美一级视 | 成人私人影院www片免费高清 | 亚洲乱亚洲乱妇41p国产成人 | 国产一区在线 | 精品国产一区二区 | 操美女 |