当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 实现按部门月卡余额总额分组统计的SQL查询代码

MSSQL
全面接触SQL语法(1)
全面接触SQL语法(2)
全面接触SQL语法(3)
全面接触SQL语法(4)
全面接触SQL语法(5)
全面接触SQL语法(6)
全面接触SQL语法(7)
跟我学SQL:(一)数据查询
跟我学SQL:(二) SELECT语句选项
精通数据库系列之入门-技巧篇2
精通数据库系列之入门-技巧篇3
精通数据库系列之入门-技巧篇4
精通数据库系列之入门-技巧篇5
SQL Server 7.0 入门(六)
Microsoft SQLServer安装示例
操作数据:SQL基础
操作数据:中级SQL
动态SQL四种类型的语句格式
Sql表数据操作
数据库正规化和设计技巧(1)

MSSQL 中的 实现按部门月卡余额总额分组统计的SQL查询代码


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 158 ::
收藏到网摘: n/a

 

陈优章的专栏

(原创,到现在为至最为复杂的SQL查询代码)实现按部门月卡余额总额分组统计的SQL查询代码(在Ms SQL Server中调试通过)

SELECT dp.dpname1 AS 部门, cust_dp_SumOddfre.sum_oddfare AS 当月卡总余额
FROM (SELECT T_Department.DpCode1, SUM(custid_SumOddfare_group.sum_oddfare)
              AS sum_oddfare
        FROM (SELECT l2.CustomerID, SUM(r1.oddfare) AS sum_oddfare
                FROM (SELECT CustomerID, MAX(OpCount) AS max_opcount
                        FROM (SELECT CustomerID, OpCount, RTRIM(CAST(YEAR(OpDt)
                                      AS char)) + '-' + RTRIM(CAST(MONTH(OpDt) AS char))
                                      + '-' + RTRIM(DAY(0)) AS dt
                                FROM T_ConsumeRec
                                UNION
                                SELECT CustomerID, OpCount, RTRIM(CAST(YEAR(cashDt)
                                      AS char)) + '-' + RTRIM(CAST(MONTH(cashDt) AS char))
                                      + '-' + RTRIM(DAY(0)) AS dt
                                FROM T_Cashrec) l1
                        WHERE (dt <= '2005-6-1')/*输入查询月份,可用参数传递*/
                        GROUP BY CustomerID) l2 INNER JOIN
                          (SELECT CustomerID, OpCount, oddfare
                         FROM T_ConsumeRec
                         UNION
                         SELECT CustomerID, OpCount, oddfare
                         FROM T_Cashrec) r1 ON l2.CustomerID = r1.CustomerID AND
       &nb