Foxtable(狐表)用户栏目专家坐堂 → 用一条sql语句如何统计出全年的租金?


  共有2423人关注过本帖树形打印复制链接

主题:用一条sql语句如何统计出全年的租金?

帅哥哟,离线,有人找我吗?
sloyy
  1楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2193 积分:13908 威望:0 精华:2 注册:2012/2/25 10:59:00
用一条sql语句如何统计出全年的租金?  发帖心情 Post By:2018/10/20 16:13:00 [只看该作者]

合同号码 合同起始日期 合同截止日期 月租金
201801 2018-01-01 2019-12-31 100
201802 2017-11-01 2018-10-31 200
201803 2017-01-01 2018-03-31 300
201803 2018-04-04 2018-11-31 400
2018年1-12月,月租金合计数
合同号码 月租金合计 备注
201801 1200 12*100
201802 2000 10*100
201803 4100 3*300+8*400

如何用一条sql语句统计出每个合同号码1-12月的月租金合计?

 回到顶部
帅哥,在线噢!
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110744 积分:563646 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2018/10/20 16:23:00 [只看该作者]

试试
s
elect 合同号码,sum(月租金)  from (select 合同号码, DateDiff(m, 合同起始日期合同截止日期) * 月租金 as 月租金 from 表A) as a group by 合同号码

 回到顶部
帅哥哟,离线,有人找我吗?
sloyy
  3楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2193 积分:13908 威望:0 精华:2 注册:2012/2/25 10:59:00
  发帖心情 Post By:2018/10/20 21:25:00 [只看该作者]

不对,你这是整个表统计,这个不难。  
现在难点就在于: 合同的统计时段被限制在2018-1-1 到2018-12=31日,
而有些合同 起始日期是在2018-1-1 之前,有些截止日期是在2018-12-31 之后,而有些合同分成了2段。这才是难点

 回到顶部
帅哥哟,离线,有人找我吗?
cd_tdh
  4楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:狐精 帖子:3209 积分:21331 威望:0 精华:0 注册:2016/3/28 16:57:00
  发帖心情 Post By:2018/10/21 9:34:00 [只看该作者]

不难啊,你自定义统计那一年,自己选择不就行了,如果只统计当年,直接获取当面的日期,取年不就可以了啊。

 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2018/10/21 12:44:00 [只看该作者]

以下是引用sloyy在2018/10/20 21:25:00的发言:
不对,你这是整个表统计,这个不难。  
现在难点就在于: 合同的统计时段被限制在2018-1-1 到2018-12=31日,
而有些合同 起始日期是在2018-1-1 之前,有些截止日期是在2018-12-31 之后,而有些合同分成了2段。这才是难点

 

1、假定统计2018年的数据;

 

2、2018年1月1日大于起始日期,取2018-1-1,否则,取起始日期;

 

3、2019年1月1日小于结束日期,取2019-1-1,否则,取结束日期;

 

4、从2、3中得到日期,直接相减,计算月数或者日数,乘以每月、每日的租金即可得到;

 

5、最后把所有租金sum起来。


 回到顶部
帅哥哟,离线,有人找我吗?
sloyy
  6楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2193 积分:13908 威望:0 精华:2 注册:2012/2/25 10:59:00
  发帖心情 Post By:2018/10/21 13:47:00 [只看该作者]

我采用了一个办法: 全年12个月 减去1月后起租的月份,减去12月前止租的月份
s elect 合同号码,月租金,(12+sum(case when 合同起始日期>'2018-01-01' then DateDiff(m,合同起始日期, '2018-01-01') else 0 end )+sum(case when 合同截止日期<'2018-12-31' then DateDiff(m, '2018-12-31',合同截止日期) else 0 end ))*月租金 as 月租金合计 from {租金明细}  group by 合同号码,月租金

得出了结果: 

合同号码 月租金 月租金合计
201801 100 1200
201802 200 2000
201803 300 900
201803 400 3200

还要再做一次分组合计,才能得出正确的结果 上面这个sql语句还要怎么改,才能一次就达到目的?  也就是说二次分组汇总
[此贴子已经被作者于2018/10/21 13:59:41编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2018/10/21 14:52:00 [只看该作者]

再写一个select语句即可,比如

 

select 合同号码, sum(月租金) as 总租金 from (本来的sql语句) as a group by 合同号码


 回到顶部
帅哥哟,离线,有人找我吗?
sloyy
  8楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2193 积分:13908 威望:0 精华:2 注册:2012/2/25 10:59:00
  发帖心情 Post By:2018/10/21 15:09:00 [只看该作者]

s elect 合同号码, sum(月租金合计) as 总租金 from (s elect 合同号码,月租金,(12+sum(case when 合同起始日期>'2018-01-01' then DateDiff(m,合同起始日期, '2018-01-01') else 0 end )+sum(case when 合同截止日期<'2018-12-31' then DateDiff(m, '2018-12-31',合同截止日期) else 0 end ))*月租金 as 月租金合计 from {租金明细} a group by 合同号码,月租金) as a group by 合同号码
合同号码 月租金合计
201801 1200
201802 2000
201803 4100

搞定!!! 谢谢大家 

 回到顶部