一个数据表里面字段有年、月、日、金额、支付方式等字段,然后现在想写个sql语句,把每一天的每种支付方式金额(支付方式有多重)排在同一行,

最后在增加一列小计当前的所有支付方式的金额。如下图:

原sql查询出来的结果是这样的:

-------------------------------------------------------------------------------------------

然后想实现的sql结果最后呈现是这样的:

这可为难了我了,简单的增删改查左右链接sql语句我还会写,这个稍微复杂一点我就不知道如何下手了。该怎么分组,然后把行增加为列呢?

去找度娘搜的时候,都不知道怎么描述自己的想搜的关键字。最后找了一位sql高手同学帮忙解决了这个问题,

人家只是一句简单的sql语句就把我的需求给实现了,实在是让我佩服!这个pivot关键是什么东东,我还第一次看见,从来没用过,这么强大!

sql语句:

  1. SELECT Year,Months,tDays,[], [BankIn],[iTunesHK] , []+[BankIn]+[iTunesHK] as total
  2. FROM ( select * from #temp) AS t
  3. PIVOT
  4. (SUM(amount) FOR [PayType] IN ( [], [BankIn],[iTunesHK])) AS t;

效果截图如下:

原文链接:http://www.cnblogs.com/tandaxia/p/4888623.html

补充:关于一个循环插入数据sql语句问题

需求:随机从一个表查出5条ID,然后插入到另外一个表中。

实现:刚开始使用游标,后面头说效率不好,影响性能,然后改成临时表插入结果集。之前没写过这种sql, 感觉效果很棒,记录一下:

  ---- 使用游标循环插入-------

  1. IF OBJECT_ID('sp_AddRecord') IS NOT NULL
  2. DROP proc sp_AddRecord
  3. GO
  4. CREATE proc sp_AddRecord
  5. @ID int -- 传入的id参数
  6. as
  7. BEGIN Tran
  8.  
  9. --使用游标循环插入到记录表中tbl_Record
  10. declare @FromID int
  11. declare Temp_Cursor cursor for --定义游标cursor1
  12. select top 5 ID from tbl_Member where ID<>@ID order by newid() -- 随机获取5ID
  13. open Temp_Cursor --打开游标
  14.  
  15. fetch next from Temp_Cursor into @FromID --将游标向下移1行,获取的数据放入之前定义的变量@ToID
  16.  
  17. while @@fetch_status=0 --判断是否成功获取数据
  18. begin
  19. --进行相应处理(跟据需要填入SQL文)
  20. insert into tbl_Record (FromID, ToID, [Status], CreateDate) values(@FromID, @ID, 0, GETDATE())
  21. fetch next from Temp_Cursor into @FromID --将游标向下移1
  22. end
  23.  
  24. close Temp_Cursor --关闭游标
  25. deallocate Temp_Cursor --释放游标
  26.  
  27. If @@ERROR <> 0 Goto Err
  28.  
  29. Select 1 As ResultStatus
  30. Commit Tran
  31. Return
  32. Err:
  33. Select 0 As ResultStatus
  34. RollBack Tran
  35. Return
  36. GO

---  使用临时表插入结果,实现同样的效果,效率更好 -----

  1. IF OBJECT_ID('sp_AddRecord') IS NOT NULL
  2. DROP proc sp_AddRecord
  3. GO
  4. CREATE proc sp_AddRecord
  5. @ID int -- 传入的id参数
  6. as
  7. BEGIN Tran
  8.  
  9. select top 5 ID Into #DatingMember from tbl_Member where ID<>@ID order by newid() -- 随机获取5个ID
  10.  
  11. insert into tbl_Record (FromID, ToID, [Status], CreateDate)
  12. Select ID,@ID As ToID,0, GETDATE()
  13. From #DatingMember
  14.  
  15. Drop Table #DatingMember --删除临时表
  16.  
  17. If @@ERROR <> 0 Goto Err
  18.  
  19. Select 1 As ResultStatus
  20. Commit Tran
  21. Return
  22. Err:
  23. Select 0 As ResultStatus
  24. RollBack Tran
  25. Return
  26. GO

复杂sql分组查询 ( pivot)的更多相关文章

  1. SQL分组查询及聚集函数的使用

    今天要做一个查询统计功能,一开始有点犯难,上午尝试大半天才写出统计sql语句,才发现自己sql分组查询及聚集函数没学好:其实就是group by子句和几个聚集函数,熟练使用统计功能很简单.在此总结下今 ...

  2. SQL分组查询group by

    注意:select 后的字段,必须要么包含在group by中,要么包含在having 后的聚合函数里. 1. GROUP BY 是分组查询, 一般 GROUP BY 是和聚合函数配合使用 group ...

  3. SQL分组查询GroupBy

    一.分组查询1.使用group by进行分组查询在使用group by关键字时,在select列表中可以指定的项目是有限制的,select语句中仅许以下几项:〉被分组的列〉为每个分组返回一个值得表达式 ...

  4. SQL 分组查询 group by

    select * from emp --deptno 为部门号 --输出每个部门的编号 和 该部门的平均工资 --group by deptno; 通过deptno分组 select deptno, ...

  5. SQL分组查询每组前几条数据

    /*第一种实现方法,效率低并且有错误*/ DECLARE @DD DATETIME SET @DD = GETDATE() SELECT a.GoodsID , a.Account , a.LastU ...

  6. SQL分组查询

      把数据分成多个逻辑组,以便能对每个组的数据进行操作,对每个组进行聚集计算. 1.创建分组 分组是在SELECT语句的GROUP BY子句中建立的 例子:         SELECT vendId ...

  7. sql 分组查询及格不及格人数

    select score as 类别,count(*) as 人数 from (select case when fen>=60 then '及格' else '不及格' end as scor ...

  8. mysql系列九、mysql语句执行过程及运行原理(分组查询和关联查询原理)

    一.背景介绍 了解一个sql语句的执行过程,了解一部分都做了什么,更有利于对sql进行优化,因为你知道它的每一个连接.where.分组.子查询是怎么运行的,都干了什么,才会知道怎么写是不合理的. 大致 ...

  9. Group by 分组查询 实战

    实战经历,由于本人在共享单车上班,我们的单车管理模块,可以根据单车号查询单车,但是单车号没有设置unique(独一无二约束),说以这就增加了单车号可能重复的风险,但是一般情况下,单车号是不会重复的,因 ...

随机推荐

  1. CentOS 7添加yum源

    RedHat下主要有两个distribution,一曰 RHEL(Red Hat Enterprise Linux) 一曰 Fedora.前者主要是供服务器使用,优点是稳定,缺点是老的掉牙,后者是供桌 ...

  2. CNN笔记

    Deep Learning是全部深度学习算法的总称,CNN是深度学习算法在图像处理领域的一个应用. 转 http://blog.csdn.net/stdcoutzyx/article/details/ ...

  3. express 框架之session

    一.什么是session? 最近在学习node.js 的express框架,接触到了关于session方面的内容.翻阅了一些的博客,学到了不少东西,发现一篇博文讲的很好,概念内容摘抄如下: Sessi ...

  4. Struts2 源码分析——项目分析

    项目知识点分析 从上一章中我们知道了接下来我们要去了解源码的项目(struts2-showcase).而这一章将讲述我三年后在次接触struts2-showcase项目是一个什么样子的情况.我有一个工 ...

  5. 【Swift学习】Swift编程之旅(四)基本运算符

    Swift支持大部分标准C语言的运算符, 且改进许多特性来减少常规编码错误.如赋值符 = 不返回值, 以防止错把等号 == 写成赋值号 = 而导致Bug. 数值运算符( + , -, *, /, %等 ...

  6. Spark程序使用groupByKey后数据存入HBase出现重复的现象

    最近在一个项目中做数据的分类存储,在spark中使用groupByKey后存入HBase,发现数据出现双份( 所有记录的 rowKey 是随机  唯一的 ) .经过不断的测试,发现是spark的运行参 ...

  7. Razor练习4

    今天练习Razor的逻辑处理.一般会使用下面 1. if 2. else 3. else if 4. switch 下面演示中,Insus.NET分别演示1,2, 4:xxx.cshtml代码如下: ...

  8. 在吉日嘎拉DotNet.WebForm中使用FluentScheduler调度任务

    有些用户一直说系统发送的邮件一直收不到,投诉系统不正常,这时候怎么洗刷冤屈呢?将发送的每一封Email都保存到数据库中,并记录发送的日志,让用户无话可说. 自己创建3个表: MessageFailed ...

  9. 使用泛型元组替代out与ref形式传参

    我们在开发的时候,都会常常遇到一个问题,如何为逻辑上返回多个对象设计方法签名.通常我们会想到使用out或ref修饰参数,或者麻烦些自己设定一个类型内部包含多个Object类型属性来接收多个返回值.这两 ...

  10. 多态(RAW)

    函数重写overwrite:当子类提供了和父类同名的虚函数时,称之为函数重写,函数的返回值类 函数名 参数列表必须完全相同 名字隐藏namehide:当子类提供了和父类同名的数据时 叫名字隐藏 函数重 ...