加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

使用 SQL 实现递归查询,获取子信息并将其作为记录返回

发布时间:2023-07-27 14:17:03 所属栏目:MsSql教程 来源:
导读:  <div class="codetitle"><a style="CURSOR: pointer" data="75484" class="copybut" id="copybut75484" onclick="doCopy(&#39;code75484&#39;)"> 代码如下:

  阅读全文

  <div class=
  <div class="codetitle"><a style="CURSOR: pointer" data="75484" class="copybut" id="copybut75484" onclick="doCopy('code75484')"> 代码如下:
 
  阅读全文
 
  <div class="codebody" id="code75484">
 
  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,用一个变量循环取值,然后删除循环中的值
 
  <div class="codetitle"><a style="CURSOR: pointer" data="67198" class="copybut" id="copybut67198" onclick="doCopy('code67198')"> 代码如下:
 
  <div class="codebody" id="code67198">
 
  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
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章