- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 MySQL 数据库:
Date Customer_ID
我怎样才能把它变成:
Customer_ID | Count_Visits_Past_Week | Count_Visits_Past_Month | Count_Visits_Past_90days | Count_Total
注意: Count_Total = 其他三个计数的总和
谢谢
最佳答案
第一步是确定指定日期范围的分界点。
这里有几个问题需要回答:您是否只想比较日期('yyyy-mm-dd')并忽略任何时间部分?
“过去一周”是指过去 7 天内,还是指自上周日以来至今,还是指最后一周,从周日到周六。
“上个月”是指上个月,从月初到月末吗?或者这是否意味着如果查询在当月 20 日运行,我们需要从上个月 20 日到今天的日期?还是昨天?
一旦我们知道了每个指定时间段相对于今天日期的开始和结束时间点,我们就可以构建计算这些日期的表达式。
例如,“过去一周”可以表示为最近 7 天的时间段:
DATE(NOW())-INTERVAL 1 WEEK -thru- DATE(NOW())
“上个月”可以表示为上个月直到今天的同一“一个月中的某一天”(例如 17 日):
DATE(NOW())-INTERVAL 1 MONTH -thru- DATE(NOW())
这实际上是第一步,确定每个指定期间的开始和结束日期。
<小时/>一旦我们有了这个,我们就可以继续构建一个查询,该查询获取带有 date
的行“计数”。每个时期内的列。
“技巧”是在查询的 SELECT 列表中的表达式中使用条件测试。如果该行要包含在“计数”中,我们将使用这些条件测试返回 1,如果应排除该行,则返回 0 或 NULL。
我更喜欢使用SUM()
聚合函数来获取“计数”。但也可以使用 COUNT()
总计的。 (如果我们使用 COUNT()
,我们需要使用一个在要排除该行时返回 NULL 的表达式。我更喜欢返回 1 或 0;我认为这使调试更容易。
以下是“计数”查询的概述。
SELECT t.Customer_Id
, SUM(IF( <some_condition> ,1,0) AS Count_something
, SUM(IF( <other_condition> ,1,0) AS Count_something_else
FROM mytable t
GROUP BY t.Customer_Id
何时 <some_condition>
为 true,我们返回 1,否则返回 0。
要测试条件表达式,通常最简单的方法是避免进行聚合,而只返回各个行:
这样,我们就可以看到每个“计数”中将包含哪些单独的行。
例如:
SELECT t.Customer_ID
, t.date
, IF(t.date BETWEEN DATE(NOW())-INTERVAL 1 WEEK AND DATE(NOW()),1,0)
AS visit_past_week
, IF(t.date BETWEEN DATE(NOW())-INTERVAL 1 MONTH AND DATE(NOW()),1,0)
AS visit_past_month
FROM mytable t
ORDER BY t.date, t.Customer_Id
该查询不返回“计数”,它只返回表达式的结果,这在测试中很有用。当然,我们想要测试返回每个期间的开始和结束日期的表达式:
SELECT DATE(NOW()) - INTERVAL 1 WEEK AS past_week_begin
, DATE(NOW()) AS past_week_end
<小时/>
通过这种方法,可以通过一次查询和一次遍历表将同一行包含在多个“计数”中。
请注意 SUM()
内的表达式下面的查询中的聚集利用了一种方便的速记方式,计算为 bool 值的表达式将在 TRUE 时返回 1,如果 false 则返回 0,或 NULL。
要使用 COUNT 聚合,我们需要确保要聚合的表达式在要“计数”该行时返回非 NULL,而在要从计数中排除该行时返回 NULL。因此,如果表达式返回的值为零,我们可以使用方便的 NULLIF 函数返回 NULL。
SELECT t.Customer_ID
, COUNT(NULLIF( t.date BETWEEN DATE(NOW())-INTERVAL 1 WEEK AND DATE(NOW()),0))
AS Count_Visits_Past_Week
, COUNT(NULLIF( t.date BETWEEN DATE(NOW())-INTERVAL 1 MONTH AND DATE(NOW()),0))
AS Count_Visits_Past_Month
, COUNT(NULLIF( t.date BETWEEN DATE(NOW())-INTERVAL 90 DAY AND DATE(NOW()),0))
AS Count_Visits_Past_90days
, COUNT(NULLIF( t.date BETWEEN DATE(NOW())-INTERVAL 1 WEEK AND DATE(NOW()),0))
+ COUNT(NULLIF( t.date BETWEEN DATE(NOW())-INTERVAL 1 MONTH AND DATE(NOW()),0))
+ COUNT(NULLIF( t.date BETWEEN DATE(NOW())-INTERVAL 90 DAY AND DATE(NOW()),0))
AS Count_Total
FROM mytable t
GROUP BY t.Customer_Id
注:NULLIF(a,b)
是 IF a IS NULL THEN return b ELSE return a
的便捷简写
返回 Count_Total 有点奇怪,因为它有可能多次“计数”同一行......但它返回的值应该与各个计数的总和相匹配。
关于日期范围内的 MySQL 频率,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22469289/
我有三个 td,并且正在尝试将每个内部的函数限制为仅该 td。我该怎么做呢?使用此代码,它会获取所有 3 个图像并将它们全部插入到 h2 之前: jQuery("td.frontpage_news")
这是所需的通用公式:if((b2-b1)=c1,True,False但是,我需要 b2-b1约等于 c1 , 在 5 内大约单位(在本例中为秒)。有没有可以处理这个的函数? 最佳答案 你也可以试试这个
我有三个整数,作为命令行参数传入后赋值给变量。我想验证每个整数都在 1-5 范围内。有没有一种方法可以在不使用如下所示的 if 语句的情况下在 Java 中完成此操作?我想避免这样做(注意伪代码):
检查某个变量 X 是否在某个变量 Z 的 n 个数字之内的最简洁方法是什么。n 是任意定义的数字(即 3)。 所以我想要 if (z {something} x){ // run code i
我的顶级 build.gradle (Gradle 2.2) 中有类似的东西 ext.repo = "https://my-artifactory-repo" buildscript { re
我只是在我的 jsp 页面中进行随机技巧和测试。我想使用 Attributes 将 request 范围对象存储在 session 范围对象中。存储后,当尝试从请求属性中提取值(存储在 session
我正在使用 Spring 。我有一个外部化属性文件。我正在按如下方式加载它。 现在我如何将 session 中的属性作为键值对保存? 我尝试编写一个扩展 ServletContextListene
我有以下范围: scope :billable, -> (range_start = nil, range_end = nil) { joins(:bids) .where("au
请看我的示例代码: var testObject = new SomeClass(); using (testObject) { //At this point how can the te
我目前在保持在 vector 范围内时遇到一些问题。 在下面的代码中,我试图检查正在检查的数字是否小于或等于它后面的数字 #include #include #include bool fun(
有人可以帮我解决下面的(简化的)代码吗?我试图从幻灯片事件函数中调用 doTheSlide() 函数。我对 JS 范围的理解仍然有点可疑。 实现这一目标的正确方法是什么?我收到此错误: Uncaugh
如何在 Swift 中检查时间是否在下午 6 点到晚上 11 点之间?我在使用 NSDateFormatter 时遇到了困难,我觉得一定有更简单的方法。 最佳答案 使用NSCalendar: let
我目前正在尝试创建一个 2D 横向滚动条,并且我目前有我的“世界”绘图(暂时是一个大白框),但我无法弄清楚世界地图的边缘与边缘之间的任何关系确保视口(viewport)始终完全被 map 覆盖。 我的
我正在学习李普曼,而且我只是在学习。我在这里尝试编写一个代码,该代码将返回 vector 中的最小元素。当我在 Codeblocks 中编译我的代码时,它说:“模板声明不能出现在 block 范围内”
我有三个日期对象。我该如何比较它们才能确定它们之间的相对差异。 oldDate = newDate() - 5; midDate = newDate() - 2.5; newDate = newDat
我需要检查对象“objCR”是否存在于当前范围内。我尝试使用以下代码。 if(objCR == null) alert("object is not defined"); 让我知道哪里错了。 最佳答案
如何检查 IP 地址是否属于私有(private)类别? if(isPrivateIPAddress(ipAddress)) { //do something } 如有
我正在开发一个 Firefox 插件,它可以转换用户通过用户选择突出显示的屏幕温度。转换后,用户选择将替换为 ID 为 alreadyconverted 的 span HTML 元素,其中包含原始温度
我正在开发一个邮资应用程序,该应用程序需要根据多个邮政编码范围检查整数邮政编码,并根据邮政编码匹配的范围返回不同的代码。 每个代码都有多个邮政编码范围。例如,如果邮政编码在 1000-2429、254
我正在使用 excel 范围进行连接:Set rng = Range("A1:A8")如果范围内的单元格之一为空,则会添加一个空格。 你如何阻止这个空间被添加? 最佳答案 假设您在那些非空单元格中有常
我是一名优秀的程序员,十分优秀!