SQL周、日、月、年数据统计
本文只是记录在项目中用到的统计的SQL语句,记一笔以防忘了
/// <summary>
/// 获取统计数据
/// </summary>
/// <param name="CKEY">店面ckey</param>
/// <param name="type">统计类型(日、周、月、年)</param>
/// <returns></returns>
[WebMethod(true)]
public static string GetData3(string CKEY, string type)
{
StringBuilder strSql = new StringBuilder(); #region SQL语句 if (type == "")
{
#region 日
strSql.AppendFormat(" WITH WeekDate ");
strSql.AppendFormat(" AS ( SELECT DATEADD(d, -DAY(GETDATE()) + 1, GETDATE()) AS riqi ");
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT riqi + 1 FROM WeekDate ");
strSql.AppendFormat(" WHERE riqi + 1 <= ( SELECT DATEADD(d, -DAY(GETDATE()), DATEADD(m, 1, GETDATE())) ) ");
strSql.AppendFormat(" ) ");
strSql.AppendFormat(" SELECT CONVERT(CHAR(8), a.riqi, 112) AS 日 ,DAY (CONVERT(CHAR(8), a.riqi, 112)) AS DDay, ");
strSql.AppendFormat(" ISNULL(tbB.日成交量, 0) AS 日成交量 , ");
strSql.AppendFormat(" CASE WHEN CONVERT(CHAR(8), a.riqi, 112) > CONVERT(CHAR(8), GETDATE(), 112) ");
strSql.AppendFormat(" THEN NULL ");
strSql.AppendFormat(" WHEN CONVERT(CHAR(8), a.riqi, 112) <= CONVERT(CHAR(8), GETDATE(), 112) ");
strSql.AppendFormat(" THEN ISNULL(tbB.日成交量, 0) ");
strSql.AppendFormat(" END AS 日成交数量 , ");
strSql.AppendFormat(" tbB.日实收金额 , ");
strSql.AppendFormat(" CASE WHEN CONVERT(CHAR(8), a.riqi, 112) > CONVERT(CHAR(8), GETDATE(), 112) ");
strSql.AppendFormat(" THEN NULL ");
strSql.AppendFormat(" WHEN CONVERT(CHAR(8), a.riqi, 112) <= CONVERT(CHAR(8), GETDATE(), 112) ");
strSql.AppendFormat(" THEN ISNULL(tbB.日实收金额, 0) ");
strSql.AppendFormat(" END AS 日实收金额2 ");
strSql.AppendFormat(" FROM WeekDate a ");
strSql.AppendFormat(" LEFT JOIN ( SELECT ( SELECT COUNT(1) ");
strSql.AppendFormat(" FROM dbo.CustomerBase base ");
strSql.AppendFormat(" WHERE CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" AND " + impomo.TotalConsumptionMon + " > 0 ");
strSql.AppendFormat(" AND TargetDate = cus.TargetDate ");
strSql.AppendFormat(" ) 日成交量 , ");
strSql.AppendFormat(" ISNULL(( SELECT SUM(Total) ");
strSql.AppendFormat(" FROM ( SELECT SUM(CONVERT(FLOAT, ISNULL(( pc1 + pc2 + pc3 + pc4 + pc5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM PaymentContent AS pay ");
strSql.AppendFormat(" WHERE PayDate = cus.TargetDate ");
strSql.AppendFormat(" AND pay.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(RecMoney, 0))) AS Total ");
strSql.AppendFormat(" FROM dbo.CardRecharge8 AS recharge ");
strSql.AppendFormat(" WHERE RechargDate = cus.TargetDate ");
strSql.AppendFormat(" AND recharge.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(( pc1 + pc2 + pc3 + pc4 + pc5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM dbo.PaymentSwimming AS payswim ");
strSql.AppendFormat(" WHERE PayDate = cus.TargetDate ");
strSql.AppendFormat(" AND payswim.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(( wp1 + wp2 + wp3 + wp4 + wp5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM WarePaymentContent AS ware ");
strSql.AppendFormat(" WHERE PayDate = cus.TargetDate ");
strSql.AppendFormat(" AND ware.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" ) B ");
strSql.AppendFormat(" ), 0) AS 日实收金额 , ");
strSql.AppendFormat(" TargetDate 日 ");
strSql.AppendFormat(" FROM dbo.CustomerBase cus ");
strSql.AppendFormat(" WHERE YEAR(TargetDate) = YEAR(GETDATE()) ");
strSql.AppendFormat(" AND MONTH(TargetDate) = MONTH(GETDATE()) ");
strSql.AppendFormat(" GROUP BY TargetDate ");
strSql.AppendFormat(" ) AS tbB ON CONVERT(CHAR(8), a.riqi, 112) = tbB.日 ");
#endregion
}
else if (type == "")
{
#region 周
strSql.AppendFormat(" WITH WeekDate ");
strSql.AppendFormat(" AS ( SELECT DATEADD(wk, DATEDIFF(wk, 0, GETDATE()), 0) AS riqi ");
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT riqi + 1 FROM WeekDate ");
strSql.AppendFormat(" WHERE riqi + 1 <= ( SELECT DATEADD(wk, DATEDIFF(wk, 0, GETDATE()), 6) ) ");
strSql.AppendFormat(" ) ");
strSql.AppendFormat(" SELECT CONVERT(CHAR(8), a.riqi, 112) AS 日 , ");
strSql.AppendFormat(" DATENAME(weekday,CONVERT(CHAR(8), a.riqi, 112)) DDay, ");
strSql.AppendFormat(" ISNULL(tbB.日成交量, 0) AS 日成交量 , ");
strSql.AppendFormat(" CASE WHEN CONVERT(CHAR(8), a.riqi, 112) > CONVERT(CHAR(8), GETDATE(), 112) ");
strSql.AppendFormat(" THEN NULL ");
strSql.AppendFormat(" WHEN CONVERT(CHAR(8), a.riqi, 112) <= CONVERT(CHAR(8), GETDATE(), 112) ");
strSql.AppendFormat(" THEN ISNULL(tbB.日成交量, 0) ");
strSql.AppendFormat(" END AS 日成交数量 , ");
strSql.AppendFormat(" tbB.日实收金额 , ");
strSql.AppendFormat(" CASE WHEN CONVERT(CHAR(8), a.riqi, 112) > CONVERT(CHAR(8), GETDATE(), 112) ");
strSql.AppendFormat(" THEN NULL ");
strSql.AppendFormat(" WHEN CONVERT(CHAR(8), a.riqi, 112) <= CONVERT(CHAR(8), GETDATE(), 112) ");
strSql.AppendFormat(" THEN ISNULL(tbB.日实收金额, 0) ");
strSql.AppendFormat(" END AS 日实收金额2 ");
strSql.AppendFormat(" FROM WeekDate a ");
strSql.AppendFormat(" LEFT JOIN ( SELECT ( SELECT COUNT(1) ");
strSql.AppendFormat(" FROM dbo.CustomerBase base ");
strSql.AppendFormat(" WHERE CKEY = '{0}'", CKEY);
strSql.AppendFormat(" AND " + impomo.TotalConsumptionMon + " > 0 ");
strSql.AppendFormat(" AND TargetDate = cus.TargetDate ");
strSql.AppendFormat(" ) 日成交量 , ");
strSql.AppendFormat(" ISNULL(( SELECT SUM(Total) ");
strSql.AppendFormat(" FROM ( SELECT SUM(CONVERT(FLOAT, ISNULL(( pc1 + pc2 + pc3 + pc4 + pc5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM PaymentContent AS pay ");
strSql.AppendFormat(" WHERE PayDate = cus.TargetDate ");
strSql.AppendFormat(" AND pay.CKEY = '{0}'", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(RecMoney, 0))) AS Total ");
strSql.AppendFormat(" FROM dbo.CardRecharge8 AS recharge ");
strSql.AppendFormat(" WHERE RechargDate = cus.TargetDate ");
strSql.AppendFormat(" AND recharge.CKEY = '{0}'", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(( pc1 + pc2 + pc3 + pc4 + pc5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM dbo.PaymentSwimming AS payswim ");
strSql.AppendFormat(" WHERE PayDate = cus.TargetDate ");
strSql.AppendFormat(" AND payswim.CKEY = '{0}'", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(( wp1 + wp2 + wp3 + wp4 + wp5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM WarePaymentContent AS ware ");
strSql.AppendFormat(" WHERE PayDate = cus.TargetDate ");
strSql.AppendFormat(" AND ware.CKEY = '{0}'", CKEY);
strSql.AppendFormat(" ) B ");
strSql.AppendFormat(" ), 0) AS 日实收金额 , ");
strSql.AppendFormat(" TargetDate 日 ");
strSql.AppendFormat(" FROM dbo.CustomerBase cus ");
strSql.AppendFormat(" WHERE DATEPART(wk, TargetDate) = DATEPART(wk, GETDATE()) ");
strSql.AppendFormat(" AND DATEPART(yy, TargetDate) = DATEPART(yy, GETDATE()) ");
strSql.AppendFormat(" GROUP BY TargetDate ");
strSql.AppendFormat(" ) AS tbB ON CONVERT(CHAR(8), a.riqi, 112) = tbB.日 ");
#endregion
}
else if (type == "")
{
#region 月 strSql.AppendFormat("SELECT YearMonth.月 , ");
strSql.AppendFormat(" tb.月成交量 , ");
strSql.AppendFormat(" CASE WHEN YearMonth.月 > MONTH(GETDATE()) THEN NULL ");
strSql.AppendFormat(" WHEN YearMonth.月 <= MONTH(GETDATE()) THEN ISNULL(tb.月成交量, 0) ");
strSql.AppendFormat(" END AS 月成交数量 , ");
strSql.AppendFormat(" tb.月实收总金额 , ");
strSql.AppendFormat(" CASE WHEN YearMonth.月 > MONTH(GETDATE()) THEN NULL ");
strSql.AppendFormat(" WHEN YearMonth.月 <= MONTH(GETDATE()) THEN ISNULL(tb.月实收总金额, 0) ");
strSql.AppendFormat(" END AS 月实收总金额2 ");
strSql.AppendFormat(" FROM ( SELECT 1 AS 月 UNION SELECT 2 UNION SELECT 3 UNION SELECT 4 UNION SELECT 5 UNION SELECT 6 ");
strSql.AppendFormat(" UNION SELECT 7 UNION SELECT 8 UNION SELECT 9 UNION SELECT 10 UNION SELECT 11 UNION SELECT 12 ");
strSql.AppendFormat(" ) AS YearMonth ");
strSql.AppendFormat(" LEFT JOIN ( SELECT ( SELECT COUNT(1) ");
strSql.AppendFormat(" FROM dbo.CustomerBase base ");
strSql.AppendFormat(" WHERE CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" AND " + impomo.TotalConsumptionMon + " > 0 ");
strSql.AppendFormat(" AND MONTH(TargetDate) = MONTH(cus.TargetDate) ");
strSql.AppendFormat(" ) 月成交量 , ");
strSql.AppendFormat(" ISNULL(( SELECT SUM(Total) ");
strSql.AppendFormat(" FROM ( SELECT SUM(CONVERT(FLOAT, ISNULL(( pc1 + pc2 + pc3 + pc4 + pc5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM PaymentContent AS pay ");
strSql.AppendFormat(" WHERE MONTH(PayDate) = MONTH(cus.TargetDate) ");
strSql.AppendFormat(" AND pay.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(RecMoney, 0))) AS Total ");
strSql.AppendFormat(" FROM dbo.CardRecharge8 AS recharge ");
strSql.AppendFormat(" WHERE MONTH(RechargDate) = MONTH(cus.TargetDate) ");
strSql.AppendFormat(" AND recharge.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(( pc1 + pc2 + pc3 + pc4 + pc5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM dbo.PaymentSwimming AS payswim ");
strSql.AppendFormat(" WHERE MONTH(PayDate) = MONTH(cus.TargetDate) ");
strSql.AppendFormat(" AND payswim.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(( wp1 + wp2 + wp3 + wp4 + wp5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM WarePaymentContent AS ware ");
strSql.AppendFormat(" WHERE MONTH(PayDate) = MONTH(cus.TargetDate) ");
strSql.AppendFormat(" AND ware.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" ) B ");
strSql.AppendFormat(" ), 0) AS 月实收总金额 , ");
strSql.AppendFormat(" MONTH(TargetDate) 月 ");
strSql.AppendFormat(" FROM dbo.CustomerBase cus ");
strSql.AppendFormat(" WHERE YEAR(TargetDate) = YEAR(GETDATE()) ");
strSql.AppendFormat(" GROUP BY MONTH(cus.TargetDate) ");
strSql.AppendFormat(" ) AS tb ON YearMonth.月 = tb.月 ");
#endregion
}
else if (type == "")
{
#region 年
strSql.AppendFormat("SELECT ( SELECT COUNT(1) ");
strSql.AppendFormat(" FROM dbo.CustomerBase base ");
strSql.AppendFormat(" WHERE CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" AND " + impomo.TotalConsumptionMon + " > 0 ");
strSql.AppendFormat(" AND YEAR(TargetDate) = YEAR(cus.TargetDate) ");
strSql.AppendFormat(" ) 年成交量 , ");
strSql.AppendFormat(" CONVERT(NVARCHAR(20),CONVERT(DECIMAL(18,2),ISNULL(( SELECT SUM(Total) ");
strSql.AppendFormat(" FROM ( SELECT SUM(CONVERT(FLOAT, ISNULL(( pc1 + pc2 + pc3 + pc4 + pc5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM PaymentContent AS pay ");
strSql.AppendFormat(" WHERE YEAR(PayDate) = YEAR(cus.TargetDate) ");
strSql.AppendFormat(" AND pay.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(RecMoney, 0))) AS Total ");
strSql.AppendFormat(" FROM dbo.CardRecharge8 AS recharge ");
strSql.AppendFormat(" WHERE YEAR(RechargDate) = YEAR(cus.TargetDate) ");
strSql.AppendFormat(" AND recharge.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(( pc1 + pc2 + pc3 + pc4 + pc5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM dbo.PaymentSwimming AS payswim ");
strSql.AppendFormat(" WHERE YEAR(PayDate) = YEAR(cus.TargetDate) ");
strSql.AppendFormat(" AND payswim.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" UNION ALL ");
strSql.AppendFormat(" SELECT SUM(CONVERT(FLOAT, ISNULL(( wp1 + wp2 + wp3 + wp4 + wp5 ), 0))) AS Total ");
strSql.AppendFormat(" FROM WarePaymentContent AS ware ");
strSql.AppendFormat(" WHERE YEAR(PayDate) = YEAR(cus.TargetDate) ");
strSql.AppendFormat(" AND ware.CKEY = '{0}' ", CKEY);
strSql.AppendFormat(" ) B ");
strSql.AppendFormat(" ), 0))) AS 年实收总金额 , ");
strSql.AppendFormat(" YEAR(TargetDate) 年 ");
strSql.AppendFormat(" FROM dbo.CustomerBase cus ");
strSql.AppendFormat(" GROUP BY YEAR(TargetDate) ");
#endregion
} #endregion DataTable table = DBHelper.GetDateTable(strSql.ToString());
string rs = Newtonsoft.Json.JsonConvert.SerializeObject(table);
return rs;
}
SQL周、日、月、年数据统计的更多相关文章
- 实现日、周、月排行统计 sql
在如今很多系统中,都需要进行日.周.月排行统计,但是在网上寻找 了一番,发现很多都是相对的周.月排行,即周排行则用当前时间减去7天.这样我个人认为并不恰当.如月排行中,假设今天是4月22日,则从3月2 ...
- C# 根据天、周、月汇总统计生成统计报表
先看核心代码: public List<DataEntity> SearchShopSalesReport(DateTimeOffset? dateFrom, DateTimeOffset ...
- 转载:SQL按照日、周、月、年统计数据的方法
转载源:http://www.jb51.net/article/42613.htm SQL按照日.周.月.季度.年统计数据的方法 方式一: --按日 select sum(consume),day([ ...
- sql 日志统计-日、周、月活跃数
近日网站需求:统计日志表的 日.周.月活跃数.最终研究了出来了,分享给大家看下. 如果有更好的sql语句也可以评论下方. --日活跃量 ), cr.AddTime, )as addtimt,COUN ...
- 数据库:sql语句分别按日,按周,按月,按季统计金额
如: 表:consume_record 字段:consume (money类型) date (datetime类型) 请问怎么写四条sql语句分别按日,按周,按月,按季统计消费总量. 如:1月 120 ...
- Java统计用户年/月/周/日网站访问量
一:准备工作,引入相关依赖: 二:运行效果图: 下一次访问 三:具体代码如下 (1):CountObjectInfo.java package cn.csrc.base.count; import ...
- Mysql按日、周、月进行分组统计
我们在用 Mysql 制作数据可视化图表时候,经常需要按照天.周.月等不同的粒度对数据进行分组统计.而我们的时间可能是 “2017/12/5 0:0:0” 这种准确的时间. 所以在进行分组之前我们需要 ...
- 用sql查询当天,一周,一个月的数据
用sql查询当天,一周,一个月的数据 数据查询,不管在网站还是在系统,都很常见,下文是介绍最常见的以日期查询的语句 select * from ShopOrder where datediff(w ...
- DB查询分析器7.01新增的周、月SQL执行计划功能
DB查询分析器7.01新增的周.月SQL执行计划功能 马根峰 (广东联合电子服务股份有限公司, 广州 510300) 1 引言 中国本土 ...
随机推荐
- Tomcat服务器本地的搭建,以及在 IDEA软件下的配置,以及项目的测试运行(基于supermvc框架下的web)
一.声明 使用了基于springmvc的supermvc的web框架.实习公司的框架. 二.tomact的下载与安装 1选择适合自己电脑配置的jdk和jre版本(截图来自tomcat的官方网站http ...
- 自己动手丰衣足食之 jQuery 数量加减插件
引言 做一个手机端的订单相关项目中,其中下订单时需要用到数量加减的控件,可以设置默认值,也可以设置最大值和最小值.使用jQuery这么长时间了,平时很少去编写属于自己的插件,现在编写的时候对立面的一些 ...
- .net 将List序列化成Json字符串
将List类型转化为Json,是我们平常开发时最常见的了.在使用中,有很多种方法,也可以使用. 第一种 第三方组件:Newtonsoft.Json.dll //转化成Json Newtonsoft.J ...
- 从零开始学习jQuery (五) 事件与事件对象
本系列文章导航 从零开始学习jQuery (五) 事件与事件对象 一.摘要 事件是脚本编程的灵魂. 所以本章内容也是jQuery学习的重点. 本文将对jQuery中的事件处理以及事件对象进行详细的讲解 ...
- JsTree实现简单的CRUD
现在需要将省市县区域这块搞成树状图的形状,由于项目使用的AngularJS+ABP+WebAPI各个模块之间数据传输形式是json格式,那么对于JsTree来说就方便很多了,只需要将json数据搞成我 ...
- Get和Post区别
1. get是从服务器上获取数据,post是向服务器传送数据.2. get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到.post是通过H ...
- 关于异步执行(Async/await)的理解(转发)
原文地址: http://blog.jobbole.com/85787/ 同步编程与异步编程 通常情况下,我们写的C#代码就是同步的,运行在同一个线程中,从程序的第一行代码到最后一句代码顺序执行.而异 ...
- Android手机总是提示:存储空间不足,解决方法
手机才有16G空间,用一段时间后,总是提示内存不足,各种清理软件都没卵用. 有一个方法立即见效: 1.进入Recovery 2.格式化 SDCard 博客园首席神棍 野生菌野菜干批发 大舍大得 小舍小 ...
- C++面试题汇集
1.在C++ 程序中调用被C 编译器编译后的函数,为什么要加extern “C”?答:首先,extern是C/C++语言中表明函数和全局变量作用范围的关键字,该关键字告诉编译器,其声明的函数和变量可以 ...
- HTML5 Canvas彩色小球碰撞运动特效
脚本简介 HTML5 Canvas彩色小球碰撞运动特效是一款基于canvas加面向对象制作的运动小球动画特效. 效果展示 http://hovertree.com/texiao/html5/39/ ...