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 引言 中国本土 ...
随机推荐
- Hadoop入门学习笔记---part2
在<Hadoop入门学习笔记---part1>中感觉自己虽然总结的比较详细,但是始终感觉有点凌乱.不够系统化,不够简洁.经过自己的推敲和总结,现在在此处概括性的总结一下,认为在准备搭建ha ...
- 用MVC做支付宝手机网页支付问题
支付宝支付接口手机网页支付 从官网扒下来的demo阿里做得还是相当不错的,只要参数改正确了基本上都是能跑通,WebForm的没什么大问题,这次要讲的主要是几个要注意的问题,因为是用MVC来做. 1.要 ...
- 在Visual Studio 2012中使用VMSDK开发领域特定语言(一)
前言 本专题主要介绍在Visual Studio 2012中使用Visualization & Modeling SDK进行领域特定语言(DSL)的开发,包括两个部分的内容.在第一部分中,将对 ...
- repeater三级嵌套绑定
<asp:Repeater ID="rpt1" runat="server" onitemdatabound="rpt1_ItemDataBou ...
- SQL SERVER 9003错误解决方法 只适用于SQL2000
SQLSERVER 9003错误解决方法 只适用于SQL2000 (只适用于SQL2000) "无法打开新数据库 'POS'.CREATE DATABASE 中止. (Microsoft S ...
- 在Windows Server 2012 R2的Hyper-V中设置虚拟机启用增强会话模式
在Windows Server 2012 R2的Hyper-V中,可以为虚拟机提供一种全新的连接方式,就是“增强会话模式”,它将让您更加方便的对虚拟机进行操作,比如分辨率的调整.设备的加载,最为方便的 ...
- C#文件或文件夹压缩和解压方法(通过ICSharpCode.SharpZipLib.dll)
我在网上收集一下文件的压缩和解压的方法,是通过ICSharpCode.SharpZipLib.dll 来实现的 一.介绍的目录 第一步:下载压缩和解压的 ICSharpCode.SharpZipLib ...
- Git 获取文件操作
1. 在本地新建存放源代码的文件夹: 2. 进入文件夹下,右击选择 Git Bash Here ,弹出git命令行窗口: 3. 运行指定 git init,初始化git: 4. git remote ...
- luogg_java学习_07_抽象类_接口_多态学习总结
这篇博客总结了半天,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 , 抽象 一种专门用来做父类,被继承的. (模板) 格式: abs ...
- Java中,方法的重写、重载的区别,以及多态的实例
首先我们要明白什么是重写和重载 重写(override):子类方法覆盖了父类的方法. (类与类之间继承的关系) 例:父类代码 public class Deng { public void Qi ...