常用的数据统计Sql 总结(转)
2016-06-14 09:25
120 查看
转:http://www.cnblogs.com/zhangweizhong/p/5577842.html
最近刚在搞一个BI的项目,里面需要大量的sql 数据统计相关运用,加深了我又对SQL的理解与使用。
所以,分享几个数据统计时常用的sql 语句总结:
1. 统计各个条件下的数据
2. 统计每日,每月,每年的数据
3. 某列去重统计
4. 行转列
5. 得到表中最小的未使用的ID号
6. 查询某一列数据不重复的数量
7. 按年统计1月到12个月的销量
最近刚在搞一个BI的项目,里面需要大量的sql 数据统计相关运用,加深了我又对SQL的理解与使用。
所以,分享几个数据统计时常用的sql 语句总结:
1. 统计各个条件下的数据
select BatchId,sum(CardSum) 总金额, sum(case when Status=1 then CardSum else 0 end) as 已使用, sum(case when Status=2 then CardSum else 0 end) as 已冻结 from GiftCard group by BatchId
2. 统计每日,每月,每年的数据
select year(AddTime) 年,month(AddTime) 月,day(AddTime) 日,COUNT(1) 数量,sum(CardSum) 销售合计 from GiftCard group by year(AddTime),month(AddTime),day(AddTime)
3. 某列去重统计
select COUNT(BatchId),COUNT(distinct BatchId),COUNT(distinct BatchName) from GiftCard
4. 行转列
SELECT * FROM ( SELECT BatchName, CardSum as TotAmount FROM GiftCard ) as s PIVOT ( SUM(TotAmount) FOR BatchName IN (zx测试商品, test新人优惠券,测试高考大放送) )AS MyPivot
5. 得到表中最小的未使用的ID号
SELECT (CASE WHEN EXISTS(SELECT * FROM GiftCard b WHERE b.Id = 1) THEN MIN(Id) + 1 ELSE 1 END) as Id FROM GiftCard WHERE NOT Id IN (SELECT a.Id - 1 FROM GiftCard a)
6. 查询某一列数据不重复的数量
select * from GiftCard a where not exists(select 1 from GiftCard where BatchName=a.BatchName and ID<a.ID)
7. 按年统计1月到12个月的销量
select year(AddTime) as '年', SUM(case when MONTH(AddTime)=1 then CardSum else 0 end ) as '一月', SUM(case when MONTH(AddTime)=2 then CardSum else 0 end ) as '二月', SUM(case when MONTH(AddTime)=3 then CardSum else 0 end ) as '三月', SUM(case when MONTH(AddTime)=4 then CardSum else 0 end ) as '四月', SUM(case when MONTH(AddTime)=5 then CardSum else 0 end ) as '五月', SUM(case when MONTH(AddTime)=6 then CardSum else 0 end ) as '六月', SUM(case when MONTH(AddTime)=7 then CardSum else 0 end ) as '七月', SUM(case when MONTH(AddTime)=8 then CardSum else 0 end ) as '八月', SUM(case when MONTH(AddTime)=9 then CardSum else 0 end ) as '九月', SUM(case when MONTH(AddTime)=10 then CardSum else 0 end ) as '十月', SUM(case when MONTH(AddTime)=11 then CardSum else 0 end ) as '十一月', SUM(case when MONTH(AddTime)=12 then CardSum else 0 end ) as '十二月' from GiftCard group by year(AddTime)
相关文章推荐
- 在oracle表中插入空字段和null测试
- Linux环境下使用定时器通过sqlldr向oracle数据库导入数据
- oracle alter session和alter system的参数详解
- MEAN全栈开发学习笔记1===>栈的安装
- Oracle SQL PLUS 执行SQL脚本文件是否执行后续SQL
- com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure
- sql基本语法
- MySql基础操作
- oracle导入dmp备份文件
- sql优化
- oracle-同义词,又学到东西了
- DB2 SQL Error: SQLCODE=-668, SQLSTATE=57016错误解决方法
- 使用AJAX方法可以不刷新页面就从服务器上获得信息(文件信息,方法,数据库中的数据)
- 数据库查询2
- 数据库 安装目录 总结
- Redis持久化,RDB和AOF
- [数据库] Oracle单表查询总数及百分比和数据横向纵向连接
- (八)企业部分之nginx+tomcat+memcached负载均衡集群搭建
- (五)企业部分之memcache
- Window下Redis安装及简单命令操作