zoukankan      html  css  js  c++  java
  • SQL-with as基本用法(源码DEMO)

     DROP TABLE #temp;
    with 
    cr as 
    ( 
    SELECT    At.SysNo AS AtSysNo ,
                        ( CASE WHEN At.Source = 1 THEN At.VendorSysNo
                               ELSE At.DistributorSysNo
                          END ) AS VdSysNo ,
                        At.Source ,
                        At.BizTypeCode ,
                        BT.Name ,
                        ABC.*
              FROM      BBCAccount.dbo.Account (NOLOCK) At
                        LEFT JOIN ( SELECT  *
                                    FROM    BBCAccount.dbo.BusinessType (NOLOCK) BT
                                    WHERE   BT.ParentCode IS NULL
                                            AND Status = 1
                                            AND BT.IsSystem = 1
                                            AND BT.SysNo IS NOT NULL
                                  ) AS BT ON At.BizTypeCode = BT.Code
                        LEFT JOIN ( SELECT  ABC.SysNo ,
                                            ABC.BizTypeCode AS ABCBTC ,
                                            ABC.AccountSysNo ,
                                            ABC.BizID ,
                                            ABC.Balance ,
                                            ABC.AdjustAmount ,
                                            ABC.AdjustType ,
                                            ABC.AdjustedBalance ,
                                            ABC.InDate
                                    FROM    BBCFinance.dbo.AccountBalanceChange (NOLOCK) ABC
                                            LEFT JOIN BBCFinance.dbo.AccountAdjustReceipt (NOLOCK)AAR  ON AAR.AccountSysNo = ABC.AccountSysNo      AND AAR.ChangeNo = ABC.BizID AND AAR.Status=2
                                  
                                          
                                  ) AS ABC ON ABC.AccountSysNo = At.SysNo 
              
    	 ) 
    	 SELECT * INTO #temp FROM cr 
    
    
    
    
    SELECT * FROM #temp WHERE    VdSysNo=2384
    
    
    
    SELECT TE.* FROM   #temp TE
    LEFT JOIN 
     (
    SELECT VdSysNo,Source, Name,MAX(InDate) AS InDate FROM #temp   WHERE VdSysNo=2384     GROUP  BY VdSysNo,Source,Name )
    AS TT ON TT.VdSysNo=TE.VdSysNo AND TT.Source = TE.Source AND TT.InDate = TE.InDate AND TT.Name = TE.Name
    WHERE TE.VdSysNo=2384
    

      

  • 相关阅读:
    JSON 在 IE 下不执行的问题
    一些UTF8编码问题
    如果你也想做一个Pinterest?
    关于apache虚拟机的NameVirtualHost错误
    如何玩转数据库设计
    mysql 导入数据时 max_allowed_packet 的问题
    几个练习题
    数组,for语句(补10.11)
    MySql数据库
    js基础(补10.10)
  • 原文地址:https://www.cnblogs.com/cykj/p/SQL-with-as.html
Copyright © 2011-2022 走看看