首页 > 数据库技术 > 详细

SQL 递归使用

时间:2015-06-12 17:24:18      阅读:414      评论:0      收藏:0      [点我收藏+]

直接贴代码吧= =

WITH CTE AS  
  (  
  -->Begin 一个定位点成员  
   SELECT COUNTRYORDERID,HSNAME, COUNTRYNAME,PARENTORDERID,
   IMPORTCURRENTSUMAMOUNT,
   IMPORTCONTRASTSUMAMOUNTPERCENTAGE,
   IMPORTCURRENTSUMAMOUNTPERCENTAGE,
   CAST(COUNTRYNAME AS NVARCHAR(max)) AS TE,0 AS Levle FROM #TempTableDetail
    WHERE PARENTORDERID IS NULL AND HSNAME IN (SELECT HSNAME FROM #TempTableData)
  -->End  
  UNION ALL  
  -->Begin一个递归成员  
   SELECT #TempTableDetail.COUNTRYORDERID, #TempTableDetail.HSNAME, #TempTableDetail.COUNTRYNAME,#TempTableDetail.PARENTORDERID,
   #TempTableDetail.IMPORTCURRENTSUMAMOUNT,
   #TempTableDetail.IMPORTCONTRASTSUMAMOUNTPERCENTAGE,
   #TempTableDetail.IMPORTCURRENTSUMAMOUNTPERCENTAGE,
   CAST(REPLICATE('  ',LEN(CTE.TE))+#TempTableDetail.COUNTRYNAME AS NVARCHAR(MAX)) AS TE,Levle+1 AS Levle  
    FROM #TempTableDetail INNER JOIN CTE  
    ON #TempTableDetail.PARENTORDERID=CTE.COUNTRYORDERID  
    --group by #TempTableDetail.HSNAME
    WHERE #TempTableDetail.HSNAME IN (SELECT HSNAME FROM #TempTableData)
  -->End  
  )

  INSERT INTO #TempResult(COUNTRYORDERID,HSNAME,COUNTRYNAME,IMPORTCONTRASTSUMAMOUNTPERCENTAGE,IMPORTCURRENTSUMAMOUNTPERCENTAGE,IMPORTCURRENTSUMAMOUNT)
  SELECT DISTINCT COUNTRYORDERID, HSNAME,TE,IMPORTCONTRASTSUMAMOUNTPERCENTAGE,
   IMPORTCURRENTSUMAMOUNTPERCENTAGE,IMPORTCURRENTSUMAMOUNT FROM CTE ORDER BY HSNAME,COUNTRYORDERID;

效果:

技术分享

SQL 递归使用

原文:http://blog.csdn.net/anpan1045535101/article/details/46472819

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!