一条SQL语句中算日销售额和月销售额

本文介绍了一种使用SQL语句来直接查询用户表与流水表,以获取每位用户的日销售额和月销售额的方法。通过使用WITH语句创建临时视图,避免了在应用程序中进行额外的数据处理。
部署运行你感兴趣的模型镜像

刚刚做项目的时候用到的

用户表:用户ID,用户名,余额

流水表:时间,用户ID,用户名,类型(0充值,1消费),变更金额

现在要查每个用户的日销售额和月销售额,本来最简单的方法是先把所有用户查出来,然后再c#代码中for循环中再select sum(changemoney) from liushui where userid=? 的

现在想试试看一个SQL语句 就查出来,经搜索得到如下 SQL语句:

 

WITH DailySales AS(
	select [user].id,[user].username,[user].balance,
	case
		when sum([liushui].changemoney) is NULL then 0
		else sum([liushui].changemoney)
	end as ri_xse 
	from [user]
	left join [liushui] on [user].id=[liushui].userid and [liushui].type=1 and [liushui].createtime between '2017-07-11 00:00:00' and '2017-07-11 23:59:59' 
	group by [user].id,[user].username,[user].balance
)
,MonthSales AS(
	select [user].id,[user].username,[user].balance,
	case
		when sum([liushui].changemoney) is NULL then 0
		else sum([liushui].changemoney)
	end as yue_xse 
	from [user]
	left join [liushui] on [user].id=[liushui].userid and [liushui].type=1 and [liushui].createtime between '2017-07-01 00:00:00' and '2017-07-31 23:59:59' 
	group by [user].id,[user].username,[user].balance
) select d.id,d.username,d.balance,d.ri_xse,m.yue_xse from DailySales D inner join MonthSales M on D.id = M.id

结果如下图:



 

查出来了,网友建议最好流水表分表,如一月一表,要不然的话以后流水表会很大很大很大。。。

先这么弄着先吧。。

您可能感兴趣的与本文相关的镜像

TensorFlow-v2.9

TensorFlow-v2.9

TensorFlow

TensorFlow 是由Google Brain 团队开发的开源机器学习框架,广泛应用于深度学习研究和生产环境。 它提供了一个灵活的平台,用于构建和训练各种机器学习模型

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值