- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个成员资格表,其中包含列 ID、Start_date、End_date、持续时间、值
ID | Start_date | End_date | Duration | Value |
1 | 2012-08-12 |2012-09-12| 30 | 10 |
2 | 2011-05-22 |2013-05-22| 720 | 2000 |
等等
我想把它变成两列,一列有日期,一年中的每一天,另一列有当天所有成员(member)值(value)/持续时间的总和。
我最终需要将其转化为每月值(value),让我清楚地了解由于运行成员(member)资格而导致的 future 预期收入。
现在我做了类似的事情
select
sum(if("2012-01-01" between start_date and end_date, total_value/duration, null)) as "2012-01-01",
sum(if("2012-01-02" between start_date and end_date, total_value/duration, null)) as "2012-01-02",
[...]
sum(if("2013-12-31" between start_date and end_date, total_value/duration, null)) as "2013-12-31"
from MembershipsTable
/* 0 行受影响,1 行找到。 1 个查询的持续时间:3,666 秒。 */
但我不知道如何轻松地总结它们以给出每月的值。我可以再次创建列的总和,但不想输入小说文本
对于当前格式来说,运行时间不是问题
我需要形状的输出
Month | Sum |
Jan 2012 |4500 |
Feb 2012 |4215,91 |
总和是该期间内所有成员(member)资格的总和,计算公式为每日价格*成员(member)资格当月的天数。
因此,如果成员(member)资格于 11 月 12 日开始,于 12 月 11 日结束,持续时间为 30,值(value)为 300,我想将 300/30*daysInNov 添加到 11 月份,12 月份相同,11 月份为 +190, 12 月 +110我需要以这种方式计算所有成员资格的总和。
有人知道吗?
最佳答案
这是一个有点丑陋的黑客,但我相信如果我正确理解您的需求,类似下面的东西会起作用。
首先,创建一个名为month_days 的表,其中包含所有月份及其开始日期和结束日期。您可以将其用作实用程序表来连接并计算每月总计。
month_days
start_date | last_date
2012-01-01 | 2012-01-31
2012-02-01 | 2012-02-29
然后,执行连接和计算,如下所示:
select format(month_days.start_date, 'MMM yyyy') AS [Month],
sum(case when (memberships.start_date > month_days.start_date AND memberships.end_date < month_days.end_date)
then datediff(day, memberships.end_date, memberships.start_date) * (value/duration)
when (memberships.start_date between month_days.start_date and month_days.end_date)
then (datediff(day, month_days.end_date, memberships.start_date) + 1) * (value/duration)
when (memberships.end_date between month_days.start_date and month_days.end_date)
then datediff(day, memberships.end_date, month_days.start_date) * (value/duration)
else (datediff(day, month_days.end_date, month_days.start_date) + 1) * (value/duration)
end) total_value
from memberships
inner join month_days
on memberships.start_date < month_days.end_date
and memberships.end_date > month_days.start_date
group by month_days.start_date
order by month_days.start_date
有很多方法可以创建 Month_days 表来实现类似的效果。
您可能还可以编写一个存储过程来迭代每个记录的月份,用每月总和填充临时表(或表变量),然后返回临时表的内容。
关于mysql - 计算每日成员(member)收入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13699518/
我们有一个包含重复用户记录的数据库,我需要根据几个因素选择“最佳”用户: 应先选择具有成员(member)资格的用户,然后再选择没有成员(member)资格的用户 成员(member)有级别,在所有条
不知道为什么 Visual Studio 发出此警告: Access of shared member, constant member, enum member or nested type thr
我有一个数据库设置来注册网站的成员(member)专用区域的成员(member)。我可以使用复选框回显所有注册成员,以便我可以选择从管理页面删除单个成员,但我似乎无法弄清楚如何在单击提交按钮时选择删除
假定前缀一元运算符可以“由不带参数的非静态成员函数或带一个参数的非成员函数实现”(§13.5.1[over.unary]/1),除了适用于任何成员/非成员函数选择的通常封装/代码重用设计原理之外,还有
拥有 struct Person { string name; }; Person* p = ... 假设没有运算符被重载。 哪个更有效(如果有的话)? (*p).name 对比 p->name
进程文件: members-area or members-area.exe 进程名称: 5-1-61-96 进程类别:存在安全风险的进程 英文描述: 
引用资料 http://msdn.microsoft.com/en-us/library/6tc47t75%28v=VS.80%29.aspx http://msdn.microsoft.com/en
这个问题在这里已经有了答案: Is there any reason to use this-> (16 个答案) 关闭 7 年前。 这有什么区别: int MyClass::getId() {
我正在制作一个网站,您需要在其中注册,然后创建一个角色来玩。我如何将注册页面中使用的表格与玩家的表格结合起来,以便玩家始终获得他创建的角色。 我有一个表members,用于存储注册用户以及角色的 ta
我处于困境中,我被委托(delegate)创建一个 PHP Web 应用程序,该应用程序允许一个人注册,然后该用户可以再注册 5 个其他用户,他注册的其他用户也可以每个注册 5 个成员。 我希望创建数
我试图在成员(member)页面上显示一个非常简单的用户名。我已经在 stackoverflow 上搜索过,但使用我发现的内容不起作用。 我使用 HTML 表单指南中非常常见的注册/登录脚本,该脚本使
我正在使用CodeIgniter,我的问题是关于MySQL查询。我有两个表,分别是成员和关系。 成员表 我正在做的是,根据member_type将所有用户添加到成员表中。如果 member_type
我有一个表,用于存储 2 个成员(成员 A 和成员 B)之间的聊天信息。现在,当成员 A 删除他的消息时,我会抛出这样的 sql 请求 $deleting = mysqli_query($connec
from bs4 import BeautifulSoup import requests r = requests.get('http://medicalassociation.in/doctor-
我有两个我无法修改的类,它们都具有完全相同的成员: class Pose1 { public: double x,y; }; class Pose2 { public: d
我正在测试服务器上运行机器人。当前 channel 中有 3 个成员(member_count of 3),但它只返回一个成员。该成员是机器人。 代码: import discord from dis
我有一个对象,我们称之为 o,以及对 o 的引用。 在o范围内,我设置了一个成员,我们称之为m。 所以在 o 中,我调用: o.m = "blah" 在 o 之外,我访问 m: console.log
我正在尝试实现自定义成员(member)资格提供程序并希望更改 GetUser 方法。问题是 GetUser 返回 MembershipUser,而我想返回 MyMembershipUser,它有两个
我的网站有一个推荐给 friend 的按钮。为了鼓励人们使用此功能,我想用积分奖励那些使用它的人(积分将兑换奖品......还不知道)。 好的,所以我有这样的结构: 表单.php 您可以在此处输入 f
我在 MySQL 中有三个表, 组(键:group_id) 成员(键:member_id) group_member_relations 键:group_id, member_id 最后一个表包含 m
我是一名优秀的程序员,十分优秀!