本文只是记录在项目中用到的统计的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周、日、月、年数据统计的更多相关文章

  1. 实现日、周、月排行统计 sql

    在如今很多系统中,都需要进行日.周.月排行统计,但是在网上寻找 了一番,发现很多都是相对的周.月排行,即周排行则用当前时间减去7天.这样我个人认为并不恰当.如月排行中,假设今天是4月22日,则从3月2 ...

  2. C# 根据天、周、月汇总统计生成统计报表

    先看核心代码: public List<DataEntity> SearchShopSalesReport(DateTimeOffset? dateFrom, DateTimeOffset ...

  3. 转载:SQL按照日、周、月、年统计数据的方法

    转载源:http://www.jb51.net/article/42613.htm SQL按照日.周.月.季度.年统计数据的方法 方式一: --按日 select sum(consume),day([ ...

  4. sql 日志统计-日、周、月活跃数

    近日网站需求:统计日志表的 日.周.月活跃数.最终研究了出来了,分享给大家看下.  如果有更好的sql语句也可以评论下方. --日活跃量 ), cr.AddTime, )as addtimt,COUN ...

  5. 数据库:sql语句分别按日,按周,按月,按季统计金额

    如: 表:consume_record 字段:consume (money类型) date (datetime类型) 请问怎么写四条sql语句分别按日,按周,按月,按季统计消费总量. 如:1月 120 ...

  6. Java统计用户年/月/周/日网站访问量

    一:准备工作,引入相关依赖: 二:运行效果图: 下一次访问 三:具体代码如下  (1):CountObjectInfo.java package cn.csrc.base.count; import ...

  7. Mysql按日、周、月进行分组统计

    我们在用 Mysql 制作数据可视化图表时候,经常需要按照天.周.月等不同的粒度对数据进行分组统计.而我们的时间可能是 “2017/12/5 0:0:0” 这种准确的时间. 所以在进行分组之前我们需要 ...

  8. 用sql查询当天,一周,一个月的数据

    用sql查询当天,一周,一个月的数据   数据查询,不管在网站还是在系统,都很常见,下文是介绍最常见的以日期查询的语句 select * from ShopOrder where datediff(w ...

  9. DB查询分析器7.01新增的周、月SQL执行计划功能

                DB查询分析器7.01新增的周.月SQL执行计划功能 马根峰              (广东联合电子服务股份有限公司, 广州 510300) 1      引言   中国本土 ...

随机推荐

  1. 如何设置 Panorama 控件的只读 SelectedIndex 属性?

    在 OnNavigatedTo() 方法中设置: panoramaControl.DefaultItem = panoramaControl.Items[indexToSet];

  2. Nancy之结合tinyfox给我们的应用提供简单的数据服务

    说到提供数据服务给我们的一些应用,估计用的最多的也就是json和xml这两种数据格式 实现的方法也是多种多样,web api,mvc的jsonresult和contentresult...等等 本文是 ...

  3. WPF语音播放MediaPlayer

    private MediaPlayer player; public MainWindow() { InitializeComponent(); player = new MediaPlayer(); ...

  4. C# 管理员身份运行程序

    在使用winform程序获取调用cmd命令提示符时,如果是win7以上的操作系统,会需要必须以管理员身份运行才会执行成功,否则无效果或提示错误. 比如在通过winform程序执行cmd命令时,某些情况 ...

  5. 高效的SQLSERVER分页查询的几种示例分析

    Sqlserver数据库分页查询一直是Sqlserver的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询 ...

  6. 如何在ASP.NET的web.config配置文件中添加MIME类型

    常常有一些特殊的MIME类型是IIS中没有的,一般来说要我们自己手动添加.如果网站经常更换服务器或者网站代码是提供给多个用户使用,那么会造成网站中用到的特殊的MIME类型要经常性的在IIS上配置.这里 ...

  7. github如何查看提交历史呢

    git日志的查看,在使用 Git 提交了若干更新之后,又或者克隆了某个项目,想回顾下提交历史,我们可以使用 git log 命令查看....... 一.查看日志信息: $ git log 可以用 -- ...

  8. 【Java每日一题】20161209

    package Dec2016; public class Ques1209 { public static void main(String[] args){ People g = new Peop ...

  9. 新建 ASP.NET Core MVC 项目 -- Hello World!

    一.创建一个空项目 请查看 新建 .NET Core 项目 -- Hello World! 一节,新建一个项目: 二.添加引用并修改配置为 MVC 修改 .vscode\launch.json 文件 ...

  10. 解决Visual C++ Redistributable for Visual Studio 2015的安装问题

    1. Visual C++ Redistributable for Visual Studio 2015系统要求:Windows 7情况下必须是Windows 7 with SP1.或者Windows ...