- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 postgresql 9.6
问题如下,我们有一个数据库来跟踪订阅业务中的订单。一旦有人订阅,每个月都会为他们生成一个订单。每个人都有能力跳过一个月(或跳过一个月的周期,或 3 等,有效地跳过 x 个月)。我正在尝试确定在给定月份“跳过”的人数。
我们有一个订单表,看起来像这样(简化):
CREATE TABLE orders (
person_id varchar,
timestamp_ timestamp
);
我可以使用窗口函数对每个人的订单进行排序,如下所示:
select timestamp_, person_id, row_number()
over (partition by person_id order by timestamp_)
from orders
输出:
timestamp_ person_id row_number
2017-03-14 12:38:38 00050c43-08c5-11e7-b433-01007e15dd78 1
2017-04-14 10:04:13 00050c43-08c5-11e7-b433-01007e15dd78 2
2017-07-14 10:05:17 00050c43-08c5-11e7-b433-01007e15dd78 3
2017-08-14 10:02:37 00050c43-08c5-11e7-b433-01007e15dd78 4
2017-09-14 10:04:37 00050c43-08c5-11e7-b433-01007e15dd78 5
2017-10-14 10:02:08 00050c43-08c5-11e7-b433-01007e15dd78 6
2017-11-14 10:05:35 00050c43-08c5-11e7-b433-01007e15dd78 7
2017-12-14 10:02:52 00050c43-08c5-11e7-b433-01007e15dd78 8
2018-01-14 10:05:38 00050c43-08c5-11e7-b433-01007e15dd78 9
2017-11-15 03:54:57 000b5c80-c9b8-11e7-a1c1-0242ac110003 1
2017-12-14 10:00:34 000b5c80-c9b8-11e7-a1c1-0242ac110003 2
2018-01-14 10:07:17 000b5c80-c9b8-11e7-a1c1-0242ac110003 3
2016-12-24 10:15:58 0017c8ad-b252-11e6-b4db-0100ab184d8f 1
2017-01-24 10:54:49 0017c8ad-b252-11e6-b4db-0100ab184d8f 2
我也一直在玩这样的滞后函数:
select timestamp_, person_id,
(date_trunc('month', timestamp_) - date_trunc('month',timestamp_))
over (partition by person_id order by timestamp_))
from orders;
给我这样的结果:
timestamp_ person_id lag
2017-03-14 12:38:38 00050c43-08c5-11e7-b433-01007e15dd78
2017-04-14 10:04:13 00050c43-08c5-11e7-b433-01007e15dd78 0 years 0 mons 31 days 0 hours 0 mins 0.00 secs
2017-07-14 10:05:17 00050c43-08c5-11e7-b433-01007e15dd78 0 years 0 mons 91 days 0 hours 0 mins 0.00 secs
2017-08-14 10:02:37 00050c43-08c5-11e7-b433-01007e15dd78 0 years 0 mons 31 days 0 hours 0 mins 0.00 secs
2017-09-14 10:04:37 00050c43-08c5-11e7-b433-01007e15dd78 0 years 0 mons 31 days 0 hours 0 mins 0.00 secs
2017-10-14 10:02:08 00050c43-08c5-11e7-b433-01007e15dd78 0 years 0 mons 30 days 0 hours 0 mins 0.00 secs
2017-11-14 10:05:35 00050c43-08c5-11e7-b433-01007e15dd78 0 years 0 mons 31 days 0 hours 0 mins 0.00 secs
2017-12-14 10:02:52 00050c43-08c5-11e7-b433-01007e15dd78 0 years 0 mons 30 days 0 hours 0 mins 0.00 secs
2018-01-14 10:05:38 00050c43-08c5-11e7-b433-01007e15dd78 0 years 0 mons 31 days 0 hours 0 mins 0.00 secs
2017-11-15 03:54:57 000b5c80-c9b8-11e7-a1c1-0242ac110003
2017-12-14 10:00:34 000b5c80-c9b8-11e7-a1c1-0242ac110003 0 years 0 mons 30 days 0 hours 0 mins 0.00 secs
2018-01-14 10:07:17 000b5c80-c9b8-11e7-a1c1-0242ac110003 0 years 0 mons 31 days 0 hours 0 mins 0.00 secs
2016-12-24 10:15:58 0017c8ad-b252-11e6-b4db-0100ab184d8f
2017-01-24 10:54:49 0017c8ad-b252-11e6-b4db-0100ab184d8f 0 years 0 mons 31 days 0 hours 0 mins 0.00 secs
我需要帮助组合这两个查询并应用按月分组
来计算当月跳过的人数:
select month, count(person_id) as skips
from ( some inner query)
group by month
要得到这样的东西:
Month Number of people who skipped subscription
2017-03-1 14
2017-04-1 8
2017-05-1 4
最佳答案
想到的方法是在每个人的第一个时间戳和最后一个时间戳之间的每个月为每个人生成一行(您可能希望为此使用固定日期)。
然后,检查哪些有订单:
select m.mon, count(*) as num_missing
from generate_series('2017-03-01'::timestamp, '2017-05-01'::timestamp, interval '1 month') m(mon) join
(select person_id, min(timestamp_) as mints, max(timestamp_) as maxts
from orders
group by person_id
) p
on m.mon between date_trunc('month', mints) and date_trunc('month', maxtx) left join
orders o
on p.person_id = o.personid and m.mon = date_trunc('month', o.timestamp_)
where o.person_id is null
group by m.mon
order by m.mon;
关于sql - 如何计算 postgresql 中每月重复事件的差距,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48509855/
我无法消除 IE7 中列表项之间的差距。 HTML: row 1.1
我用 jquery mobile 开发了一个 Phonegap 应用程序。它是一个单页应用程序,具有固定的页眉、固定的页脚和从左侧打开的面板。内容 DIV 为白色,面板从其默认颜色加载。 问题是当面板
我在我当前的元素中使用了 bootstrap,它工作正常但只有一个故障: 我有 3 col-sm-6彼此相邻,当第二个col-sm-6比第一、第三长col-sm-6向左移动,第一个和第三个之间出现间隙
我目前正在创建一个网站。但是,我在缩小页面最右侧的边距差距时遇到了一些问题 As seen in this picture我尝试将 body 设置为 margin 0px,但这没有帮助。任何帮助都将不
我的 OpenLayers map 有问题。我无法让瓷砖一 block 挨着另一 block 。我已经检查过侵入式 CSS,但没有找到任何东西。有人可以帮我解决这个问题吗? 我目前的代码是这样的:
我在制作 时遇到了问题我页面的标题链接展开以填满整个 在我的网页中标记。下面似乎有一个缺口,我不知道如何修复它。 我的导航栏也有类似的问题,随着我增加浏览器的大小,它不断扩展。 尝试将鼠标悬停在这个
当使用 Xcode 11 beta 5 在 iOS 13 beta 6 上运行应用程序时,我在呈现搜索结果 View Controller 时遇到了奇怪的间隙: 以下是如何设置的一些内容: let s
(PostgreSQL 8.4) 继续我的 previous example ,我希望通过窗口函数进一步理解间隙和孤岛处理。考虑下表和数据: CREATE TABLE T1 ( id SERIAL
我正在开发 PWA 网站。必须通过单击主屏幕图标来启动应用程序。问题是将 iPhone 旋转到横向位置后出现 20px 间隙。这个间隙超出了 Window 对象,所以我无法用 js 或 css 处理它
我注意到当位置设置为绝对时,表格单元格垂直对齐不起作用。我做错了什么吗? 非工作 sample bottom alignament is
我尝试添加各种标签并尝试添加相对路径:'//' 这些是我尝试过的各种meta标签 我也尝试过为相对路径添加“//”。 execIframe.contentWindow.location
我有一个 CSS 嵌套菜单在 IE 8 和 Firefox 中完美运行,但在 IE7 中它会在元素之间产生一个小间隙。这是我的 CSS: #nav, #nav ul { margin: 0;
我正在尝试使用 SwiftUI 在 HStack 中有两个 View 。但是,我一直在两种观点之间存在差距。 该问题出现在纵向和横向布局中。 我的代码: struct ContentView: Vie
我的 svg 左侧有一个小缝隙,我一辈子都无法修复它。请参阅下图了解我所指的内容。在左侧,您可以稍微看到图像。 我在 Chrome 和 Firefox 上注意到这个问题。知道问题可能是什么吗? .aw
当我在 Visual Studio 2010 中创建一个全新的 ATL 项目时,资源 ID 102 和 105 被遗漏了。这是故意的还是错误?这些 ID 在项目后期有什么用吗?我可以重新排序编号以使用
我使用 JQuery Mobile+Phone Gap 实现了 TableView A Adam Kinkaid Alex Wickerham Avery Johnson B
我是一名优秀的程序员,十分优秀!