- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
根据 @gordon 的评论进行编辑 ---
假设以下场景
CREATE TABLE card (date_field, numcard, month);
INSERT INTO card (date_filed, numcard, month)
VALUES
(2018-06-01, 12531, June-2018),
(2018-06-02, 29182, June-2018),
(2018-05-01, 12781, May-2018),
(2018-05-29, 56171, May-2018),
(2018-05-10, 27191, May-2108),
(2018-04-10, 83231, April-2018),
(2018-03-01, 31131, March-2018),
(2018-03-02, 47131, March-2018),
(2018-02-15, 34617, February-2018);
在这种情况下,我尝试使用一个查询来获取 2018 年 6 月 (M)、2018 年 5 月 (M-1) 和 2018 年 3 月 (M-3) 的卡号...以及输出应该是像这样的 1X3 矩阵... Desired Output
我尝试使用下面的查询来解决它:
in the quest to solve my question, I came across this discussion MySQL Query to calculate the Previous Month and this one : MySQL: Select previous month and month before
SELECT count(*) as 'M', '' as'M-1', '' as 'M-3' FROM my_table WHERE YEAR(date_field) = YEAR(CURRENT_DATE - INTERVAL 2 MONTH) AND MONTH(date_field) = MONTH(CURRENT_DATE - INTERVAL 2 MONTH)
UNION
SELECT '' as 'M', count(*) as'M-1', '' as 'M-3' FROM my_table WHERE YEAR(date_field) = YEAR(CURRENT_DATE - INTERVAL 3 MONTH) AND MONTH(date_field) = MONTH(CURRENT_DATE - INTERVAL 3 MONTH)
UNION
SELECT '' as 'M', '' as 'M-1', count(*) as 'M-3' FROM my_table WHERE YEAR(date_field) = YEAR(CURRENT_DATE - INTERVAL 4 MONTH) AND MONTH(date_field) = MONTH(CURRENT_DATE - INTERVAL 4 MONTH)
...它给出了
仅对角线上有值(位:-( ...)。
我想要的是这个
.
*** 感谢您的帮助和见解。周末愉快!
最佳答案
您可以使用条件聚合。只计算满足条件的行。使用 CASE
执行此操作,如果满足条件,则返回任何非空值。否则,CASE
将默认返回 null,并且如果 ex
计算结果为 NULL
,则 count(ex)
不会计算行。 code>,该行不计算在内。
您可能还想以某种方式重新处理您的条件,即 date_field
是比较运算符一侧的完整表达式,以便可以将 date_field
上的索引用过的。 (对于 WHEN
中的表达式来说并不那么重要,但对于 WHERE
子句中的表达式来说并不那么重要。)
SELECT count(CASE
WHEN date_field >= current_date - interval 2 month - interval dayofmonth(current_date) - 1 day
AND date_field < current_date - interval 1 month - interval dayofmonth(current_date) - 1 day THEN
1
END) `M`,
count(CASE
WHEN date_field >= current_date - interval 3 month - interval dayofmonth(current_date) - 1 day
AND date_field < current_date - interval 2 month - interval dayofmonth(current_date) - 1 day THEN
1
END) `M-1`,
count(CASE
WHEN date_field >= current_date - interval 4 month - interval dayofmonth(current_date) - 1 day
AND date_field < current_date - interval 3 month - interval dayofmonth(current_date) - 1 day THEN
1
END) `M-3`,
FROM my_table
WHERE date_field >= current_date - interval 4 month - interval dayofmonth(current_date) - 1 day
AND date_field < current_date - interval 1 month - interval dayofmonth(current_date) - 1 day;
关于mysql - SELECT UNION : MySQL Select month, 上个月 - 1,上个月 - 3,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51677026/
我正在处理一些遗留代码,其中 java.util.Calendar 用于与日期相关的计算(基本上是添加月份)。现在我想在代码中用 java.time.LocalDate 替换 java.util.Ca
我刚刚在我正在学习的类(class)中开始使用 R,到目前为止我所做的是制作一个加载文件的脚本。 如果重要的话,我正在使用 Rstudio 1.0.44 使用 Ubuntu 14.04 运行 R。 我
我正在按月查询在 Laravel 中创建的用户,这是我的代码 $devlist = DB::table("users") ->select("id" ,DB::ra
C++20 计时类型/值之间有什么区别 month{7}和 months{7} ?有两个如此相似的名字是不是很困惑? 最佳答案 是的,同时拥有 month 可能会令人困惑。和 months第一次遇到这
我有一个数据库,其中包含我的用户完成的每个操作,并带有时间戳,如下所示: 用户名 ; Action ; 创建日期 我想评估一段时间内活跃用户的数量。我可以看到每周活跃的用户数 (count (dist
我在我的 Python 脚本中使用了 parsedatetime 库,似乎“上个月”有效,“下个月”但“本月”无效。 我错过了什么?有没有办法获取当月的第一天? 编辑:抱歉,这是一些代码: impor
我发现的大部分信息都不在 python>pandas>dataframe 中,因此是这个问题。 我想将 1 到 12 之间的整数转换为缩写的月份名称。 我有一个 df,它看起来像: client
在用户单击“下个月”或“上个月”后,我需要使用自定义 CSS 重新填充日期选择器。我正在点击 onChangeMonthYear 事件,但不知道用户要去哪条路(下个月或上个月)。有什么简单的内置东西可
我正在尝试计算一个月内产品的总销售额,但我希望它包括任何“空”月份(没有销售额)并且只选择最近的 12 个月。 到目前为止,这是我的代码。 declare @ProductNo int set @Pr
我有一个独特的问题,我根本无法解决。 所以我在 SQL Server 2005 中,我得到了以下要处理的数据: FISCAL_YEAR_START_MONTH INT(财政年度的第一个月) COUNT
我正在进行的一个项目需要获取过去 12 个月中每个月的平均发票总额。我可以通过执行 12 个查询(每月 1 个)轻松获得我需要的内容,但它非常丑陋,我最终得到 12 个唯一变量(id 而不是有一个循环
我希望用更好的不太详细的过程替换以下函数,用于从字符串确定数字月份值。有谁知道是否有可用于此目的的日期/日期时间函数?我没有注意到任何一个可以满足我的需求。 代码中的文本字符串正是我接收它们的方式。
我正在尝试获取过去 12 个月(包括当月)按月分组的记录数。不是从今年年初开始。 我有一个表 EVENTS 和一个字段 WODATE。我能做到 aFDQuery.Connection := Tra
我正在使用moment.js在 angularjs 应用程序中进行日期转换。我要打印Month number作为Month name 。我已经尝试过如下, {{item.ReviewMonth | d
我想通过 JPA 从 Oracle 数据库中选择实体,方法如下: Calendar cal = Calendar.getInstance(); cal.setTime(anOtherDate); Qu
我希望用一个更好的更简单的过程来替换以下函数,以便从字符串中确定数字月份值。有谁知道是否有可用于此的 Date/DateTime 函数?我没有注意到可以满足我的需求的。 代码中的文本字符串正是我接收它
我正在尝试获取过去 12 个月(包括当月)按月分组的记录数。不是从今年年初开始。 我有一个表 EVENTS 和一个字段 WODATE。我能做到 aFDQuery.Connection := Tra
我读到“将日期字符串转换为mysql日期时间字段”:但这对我没有帮助 所以我想做的是将dat文件读入mysql中的空表。 table CLIMBED(TRIP_ID int,PEAK VARCHAR(
我有这样的查询: SELECT EXTRACT(MONTH FROM d.mydate) AS synmonth, SUM(apcp) AS apcptot FROM t_synop_data2 d
一些需要更改 df header 的 Django 格式问题。 测试数据: Test_Data = [ ('Year_Month', ['Done_RFQ','Not_
我是一名优秀的程序员,十分优秀!