- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图返回连续两个月或更多个月满足 >=10 FactCount 阈值的行。
这是我当前拥有的输出示例,查询如下。
我将如何实现这一目标?如果有什么我可以澄清的,请发表评论。感谢您的意见!
现有表
CREATE TABLE foo AS SELECT * FROM ( VALUES
( 5454, 201601, 5),
( 5454, 201602, 3),
( 5454, 201603, 11),
( 5454, 201604, 10),
( 5454, 201605, 6),
( 9987, 201601, 2),
( 9987, 201602, 0),
( 9987, 201603, 12),
( 9987, 201604, 5),
( 9987, 201605, 7)
) AS t(userid , yearmonth , factcount);
期望的输出
+--------+-----------+-----------+
| UserID | YearMonth | FactCount |
+--------+-----------+-----------+
| 5454 | 201601 | 5 |
+--------+-----------+-----------+
| 5454 | 201602 | 3 |
+--------+-----------+-----------+
| 5454 | 201603 | 11 |
+--------+-----------+-----------+
| 5454 | 201604 | 10 |
+--------+-----------+-----------+
| 5454 | 201605 | 6 |
+--------+-----------+-----------+
查询:
SELECT
UserID
,YearMonth
,SUM(FactCount) AS sumFact
,CASE WHEN sumFact>=10 THEN 1 ELSE 0 END AS FactCount_>=10_Flag
FROM
tbl
GROUP BY
UserID
,YearMonth
最佳答案
我认为这实际上是你想要的......
WITH t AS (
SELECT userid,
make_date(
substring(yearmonth::text, 1, 4)::int,
substring(yearmonth::text, 5, 2)::int,
1
) AS yearmonth,
factcount
FROM foo
)
SELECT userid, dategroup, count(*)
FROM (
SELECT
userid,
yearmonth,
factcount,
count(is_reset) OVER (PARTITION BY userid ORDER BY yearmonth) AS dategroup
FROM (
SELECT
userid,
yearmonth,
factcount,
CASE WHEN (lag(yearmonth) OVER (PARTITION BY userid ORDER BY yearmonth) + '1 month'::interval)::date <> yearmonth THEN 1 END AS is_reset
FROM t
WHERE factcount >= 10
) AS t2
) AS t3
GROUP BY userid, dategroup
HAVING count(*) > 1;
那么首先,为了解决201612
的问题滚入201701
而不是 201613
我们需要将这些移动到我们可以使用的地方,即 date
这里我们转换yearmonth
日期类型,
SELECT userid,
make_date(
substring(yearmonth::text, 1, 4)::int,
substring(yearmonth::text, 5, 2)::int,
1
) AS yearmonth,
factcount
FROM foo
我把它放在 CTE 中是因为
YYYYMM
这样存储日期接下来我们从内到外工作..
SELECT
userid,
yearmonth,
factcount,
CASE WHEN (lag(yearmonth) OVER (PARTITION BY userid ORDER BY yearmonth) + '1 month'::interval)::date <> yearmonth THEN 1 END AS is_reset
FROM t
WHERE factcount >= 10
我们来了
factcount>10
的行.您正在运行的此统计信息会忽略其他统计信息。1
的新虚拟列如果datemonth
不成功(在)前一行的 datemonth
之后专栏。这将返回一个这样的集合,
userid | yearmonth | factcount | is_reset
--------+------------+-----------+----------
5454 | 2016-03-01 | 11 |
5454 | 2016-04-01 | 10 |
9987 | 2016-03-01 | 12 |
9987 | 2016-05-01 | 19 | 1
然后我们再次包装它,并且count()
我们的 is_reset
count(is_reset) OVER (PARTITION BY userid ORDER BY yearmonth) AS dategroup
这将返回一个这样的集合,
userid | yearmonth | factcount | dategroup
--------+------------+-----------+-----------
5454 | 2016-03-01 | 11 | 0
5454 | 2016-04-01 | 10 | 0
9987 | 2016-03-01 | 12 | 0
9987 | 2016-05-01 | 19 | 1
现在我们
userid
, 和 dategroup
这会向您显示所有连续几个月的用户 factcount>10
不分年份。
userid | dategroup | count
--------+-----------+-------
5454 | 0 | 2
而且,作为额外的奖励,因为无论如何它都必须完成工作,它会告诉您
factcount > 10
所以你可能会看到类似的东西,
userid | dategroup | count
--------+-----------+-------
5454 | 0 | 3
5454 | 1 | 2
但是,我认为出于您的目的,您可以使用该输出来做任何您想做的事情。即,SELECT DISTINCT userid
然后 JOIN
到主表,如果所有用户的所有行都有两个或多个连续的月份 factcount > 10
.
关于sql - 如何返回连续两天或更多天/月/季度符合条件的行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41271079/
我们如何让 SwiftUI 对象,尤其是 Image,符合 Hashable 协议(protocol)? 我知道它们符合 Equatable 协议(protocol),所以主要问题是如何获取哈希值,或
我遇到了一些符合 AVAudioPlayerDelegate 的奇怪问题。以下正是我在一个全新的 Xcode 项目中所拥有的: import UIKit import AVFoundation cla
我一辈子都弄不明白为什么我会收到此类不符合 NSCoding 协议(protocol)的错误。也许另一双眼睛会有所帮助。我试图添加注释以明确每个函数在做什么。 import Foundation im
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 9 年前。 Improve t
所有现代浏览器都理解 HTML,所以除了在键盘最右侧编写更多字符之外,兼容 XHTML 的意义何在。 最佳答案 没有一点我能想到的。 W3C 已经取消了 XHTML 2.0,尽管应该有一个 XHTML
我正在设计一个订单系统,状态设计模式似乎很合适,因为订单可以更改其状态,从而更改订单允许的功能。下面是我的基本类图: 我不喜欢这种方法,因为客户端无法查看某个方法是否受支持并且违反了里氏原则。我在下面
我正在考虑使用图形数据库来存储 IFC数据。理想情况下,数据库应该提供一种方法来定义 IFC 架构中定义的所有规则类型。但是,我不认为有任何这样的数据库,因为 IFC 中的某些规则类型非常复杂并且需要
我所在的组织必须满足 FISMA 对启用 FIPS 的系统的要求。我正在尝试做的一件事是为我们的密码实现哈希算法。我对此有很多选择:SHA-2、MD5、bcrypt(使用 Blowfish)、RIPE
我正在尝试实现我的自定义 CoreData Carpark 实体以符合 MKAnnotation,就像我们如何使 class 对象符合 >MKAnnotation. 我根据以下帖子调整了我的实现:th
我在 project-Swift.h 文件中收到名为“CBCentralManagerDelegate”的 No 类型或协议(protocol)。不知道我在这里哪里出错了。我认为这与 swift.h
我正在尝试读取之前写入 NVM 闪存的变量的值。 我的代码是: uintptr_t address = getAddress(); //[MISRA C++ Rule 5-2-8] cast from
所以我有这个练习要解决。我必须创建第一个。一个名为 Printable 的接口(interface),它有一个 put() 方法,该方法将接受实现 Comparable 的对象。 完成 interfa
我的问题涉及 IEEE 754 单精度数字。假设我有一个结构: typedef struct __ieee754 { int sign; int exponent; int mant
我需要使用 map,键为 uint32_t,值为 Meshes。我希望将网格布局在连续的内存中以 boost 性能,因为它们将经常被连续访问。 我想知道有哪些内存分配器库可以提供以下内容; 分配给连续
在处理小对象时,有哪些分配器可用于 STL。我已经尝试过使用 Boost 的池分配器,但没有得到任何性能提升(实际上,在某些情况下性能下降相当大)。 最佳答案 你没有说你使用的是什么编译器,但它可能带
我想做什么 我有一种划分事物的方法。此方法不会对数组进行完全排序;它只是简单地对数组进行分区,以便一侧的所有元素(某些预先确定的“中心”或“中点值”——但它不必导致均匀拆分)小于“中心”和另一侧的所有
假设我需要开发一个 REST 银行应用程序允许创建/销毁银行账户以及对帐户进行以下操作:withdraw/credit/getBalance。 创建帐户 PUT/银行/约翰 这里我使用 PUT 而不是
假设我有一个 struct 符合我的模型的 Equatable,如下所示: struct Model: Equatable { var a: Int = 0 var b: String
我目前正在研究 Decodable、Encodable 和 friend ,试图理解它背后的“魔法”。 以下是我发现不寻常的一件事: class Person: Decodable { var n
在 Swift 书中,枚举的例子很好用 enum CompassPoint: String { case north, south, east, west } var northCom = C
我是一名优秀的程序员,十分优秀!