程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL >> SQL暫時表遞歸查詢子信息並前往記載的代碼

SQL暫時表遞歸查詢子信息並前往記載的代碼

編輯:MSSQL

SQL暫時表遞歸查詢子信息並前往記載的代碼。本站提示廣大學習愛好者:(SQL暫時表遞歸查詢子信息並前往記載的代碼)文章只能為提供參考,不一定能成為您想要的結果。以下是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
==============================

假如斟酌having
語句寫成:
select 先生,sum(成就) from A group by 先生 having 成就=80;
獲得成果就是如許的

先生 成就
張三 80
李四 160

用having比 JOIN ON 絕對好懂得一些,簡略一些。

mysql中group by having 用法須要留意的事項:

GROUP BY:

group by 有一個准繩,就是 select 前面的一切列中,沒有應用聚合函數的列,必需湧現在 group by前面。

好比:

select name,sum(point) from table_name

如許sql語句會報錯,必需寫成:


select name,sum(point) from table_name GROUP BY name

HAVING

把 HAVING 參加 SQL 的緣由是,WHERE 沒法運用於算計函數,而假如沒有 HAVING,就沒法測試成果前提。


select name,sum(point)
from table_name GROUP BY name
HAVING sum(point)>1000

having平日和group by結合應用.

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved