- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设您有一张客户表,日期如下:
[客户表]
+----------+-----------+----------+
| customer | date | purchase |
+----------+-----------+----------+
| 1 | 1/01/2016 | 12 |
+----------+-----------+----------+
| 1 | 1/12/2016 | 3 |
+----------+-----------+----------+
| 2 | 5/03/2016 | 5 |
+----------+-----------+----------+
| 3 | 1/16/2016 | 6 |
+----------+-----------+----------+
| 3 | 3/22/2016 | 1 |
+----------+-----------+----------+
我想编写一个查询来计算在过去 10 天内有多少不同的客户购买了一个滚动周期,从每个日历日开始并向后计算 10 天。因此,对于 2016 年的每个独特的日子,最终输出将是一个日历,其中每一天都有一个不同的客户计数,这些客户存在于日历当天的前 10 天,如下所示:
[结果表]
+-----------+------------------+
| date | unique customers |
+-----------+------------------+
| 1/01/2016 | 112 |
+-----------+------------------+
| 1/02/2016 | 104 |
+-----------+------------------+
| 1/03/2016 | 140 |
+-----------+------------------+
| 1/04/2016 | 133 |
+-----------+------------------+
| .... | 121 |
+-----------+------------------+
我想出的一个解决方案是创建一个只有一列的日历表,然后使用不等式连接将日历表连接到客户表。我认为这是非常低效的,并且正在寻求更快的解决方案。所以我的第一步是像这样创建一个日历:
[日历]
+-----------+
| date |
+-----------+
| 1/01/2016 |
+-----------+
| 1/02/2016 |
+-----------+
| 1/03/2016 |
+-----------+
| 1/04/2016 |
+-----------+
| 1/05/2016 |
+-----------+
然后对于该日历中的每一天,为了计算每一天之前的不同客户集,我加入了一个不等式,如下所示:
select
count(distinct customer) as unique customers
from calendar c
left join mytable m
on c.date>=m.date and m.date>=c.date-10
虽然我相信这是正确的,但它运行得非常慢(假设一个日历有 2 年的时间有几百万客户)。是否有 oracle 分析函数可以帮到我?
最佳答案
Is there an oracle analytic function that may help me out here?
不是真的 - 来自 COUNT()
documentation :
If you specify
DISTINCT
, then you can specify only thequery_partition_clause
of the analytic_clause. Theorder_by_clause
andwindowing_clause
are not allowed.
您可能需要 DISTINCT
和 windowing_clause
,这是不允许的。
更新:
使用按客户分区的非DISTINCT
分析查询组合,然后按天聚合,您可以获得与无效语法相同的效果:
Oracle 设置:
CREATE TABLE table_name ( customer, dt ) AS
SELECT 1, DATE '2017-01-10' FROM DUAL UNION ALL
SELECT 1, DATE '2017-01-11' FROM DUAL UNION ALL
SELECT 1, DATE '2017-01-15' FROM DUAL UNION ALL
SELECT 1, DATE '2017-01-20' FROM DUAL UNION ALL
SELECT 2, DATE '2017-01-12' FROM DUAL UNION ALL
SELECT 2, DATE '2017-01-19' FROM DUAL UNION ALL
SELECT 3, DATE '2017-01-10' FROM DUAL UNION ALL
SELECT 3, DATE '2017-01-13' FROM DUAL UNION ALL
SELECT 3, DATE '2017-01-15' FROM DUAL UNION ALL
SELECT 3, DATE '2017-01-20' FROM DUAL;
查询:
注意:下面的查询只是查询一个月的数据和前两天的范围来说明原理,但是把参数改成12个月10天也很容易。
SELECT day,
SUM( has_order_in_range ) AS unique_customers
FROM (
SELECT customer,
day,
LEAST(
1,
COUNT(dt) OVER ( PARTITION BY customer
ORDER BY day
RANGE BETWEEN INTERVAL '2' DAY PRECEDING
AND INTERVAL '0' DAY FOLLOWING )
) AS has_order_in_range
FROM table_name t
PARTITION BY ( customer )
RIGHT OUTER JOIN
( -- Create a calendar for one month
SELECT DATE '2017-01-01' + LEVEL - 1 AS day
FROM DUAL
CONNECT BY DATE '2017-01-01' + LEVEL - 1 < ADD_MONTHS( DATE '2017-01-01', 1 )
) d
ON ( t.dt = d.day )
)
GROUP BY day
ORDER BY day;
输出:
DAY UNIQUE_CUSTOMERS
------------------- ----------------
2017-01-01 00:00:00 0
2017-01-02 00:00:00 0
2017-01-03 00:00:00 0
2017-01-04 00:00:00 0
2017-01-05 00:00:00 0
2017-01-06 00:00:00 0
2017-01-07 00:00:00 0
2017-01-08 00:00:00 0
2017-01-09 00:00:00 0
2017-01-10 00:00:00 2
2017-01-11 00:00:00 2
2017-01-12 00:00:00 3
2017-01-13 00:00:00 3
2017-01-14 00:00:00 2
2017-01-15 00:00:00 2
2017-01-16 00:00:00 2
2017-01-17 00:00:00 2
2017-01-18 00:00:00 0
2017-01-19 00:00:00 1
2017-01-20 00:00:00 3
2017-01-21 00:00:00 3
2017-01-22 00:00:00 2
2017-01-23 00:00:00 0
2017-01-24 00:00:00 0
2017-01-25 00:00:00 0
2017-01-26 00:00:00 0
2017-01-27 00:00:00 0
2017-01-28 00:00:00 0
2017-01-29 00:00:00 0
2017-01-30 00:00:00 0
2017-01-31 00:00:00 0
关于sql - oracle SQL选择过去x天滚动期间的不同客户,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42265685/
我有一个问题,但由于 this question 部分正在解决,但我想知道如何计算给定间隔之间的天数。 这是一个计算员工休假天数的查询。所以给定(或不给定)一个日期范围,我想计算给定间隔之间有多少假期
变量dateSubtract结果是 16,但我想找到这 2 天之间的总天数,应该是 165。没有 JODA TIME 我该如何做到这一点? String date = "06/17/2014"; Da
我想选择创建日期介于给定月份的第一天和最后一天之间的记录。我通过以下方式计算开始日期和结束日期的月份: 日期“月份”只是时间范围内的随机日期 Calendar cal = Calendar.getIn
我有一个对你们大多数人来说可能微不足道的问题。我尝试了很多,没有找到解决方案,所以如果有人能给我提示,我会很高兴。起点是每周 xts -时间序列。 月周值(value)目标 2011 年 12 月 W
我有一个 Facebook 应用程序,它将用户生日作为 varchar 存储在 mysql 数据库中。我正在尝试获取所有用户的生日 1周后推出,如果是在本周如果生日是上周。 在我的 php 中,我获取
我正在使用以下代码来获取年、月、日中的两个日期之间的差异 tenAppDTO.getTAP_PROPOSED_START_DATE()=2009-11-01 tenAppDTO.getTAP_PRO
我想检查当前时间(在 C++ 中)是否在一个时间范围内。 我想从元组 ("12:00", "17:30") 构造时间范围,即 (string, string) 并检查时间 now() 是否介于两者之间
gitlab 有一个功能,如果我在提交消息中放入票号,那么提交将与 gitlab.com 上的票相关联。 这在进行代码审查时非常方便。不幸的是,开发人员有时会忘记这样做。 我想指定 git hooks
我正在尝试制作使用SQLite数据库的简单注册/登录应用程序,到目前为止我得到了这段代码。这是我的“注册” Activity ,我猜它应该在按下注册按钮后将用户名和 pin(密码)实现到数据库,遗憾的
我正在尝试打开、关闭和写入文件。每当我尝试打开一个文件时,如果我提供的路径中不存在该文件,程序就会告诉我。如果存在,程序将读取其中的内容并显示它。如果用户不想查找文件,可以选择创建文件并用数据填充它。
我想要我的至slideToggle每当发生 react 性变化时,但到目前为止我还无法使其发生。我尝试在 rendered 中使用 JQuery和created模板的事件,但它没有触发。 触发此操作的
我们的 MySQL 遇到了神秘的网络问题。简单的更新查询(使用索引更新单行)通常会立即运行,然后有时(假设 1000 次中有 1 次)因超时而失败。与简单的插入查询相同。数据库没有过载。我们怀疑网络问
我正在使用 actionbarsherlock 的 ActionBar,第一次以横向或水平方向运行应用程序时,选项卡以 Tabs Mode 显示。将方向更改为纵向后,导航模式仍在 Tabs 中。第二次
每天晚上(太平洋标准时间晚上 8 点)我都会对生产数据库(innoDB 引擎)进行全局备份。 这是 mysqldump 命令: mysqldump -u$MYSQLUSER -p$MYSQLPWD -
当我的应用程序第一次启动时,它应该显示用户协议(protocol),这是一个 59kb 的 txt 文件。由于读取文件并将其附加到 TextView 需要一些时间,因此我决定在异步任务中执行此操作并在
如何只允许一个“.”在按键期间的javascript中? 我这里有一个代码: function allowOneDot(txt) { if ((txt.value.split(".")
我已经创建了像主页和用户这样的标题图标。在桌面 View 中,如果我单击用户图像,它会显示相应的重定向页面。如果我在选项卡或移动 View 中将其最小化, 它什么都不显示。此问题仅发生在用户图像上,而
下面的代码在 Release模式下工作,并且仅在 Debug模式下在 g_ItemList.push_back() 引发错误,我浏览了一些 SO 帖子和论坛。有人提到 "You can't itera
我遇到了一个我似乎无法解决的 mmap 问题。下面是设置:我使用 malloc 将一个巨大的多维数组分配到内存中,用我的值填充它,然后我想将它保存在一个文件中。该数组包含 3200000000 个字节
尝试加载共享库: handle = dlopen( "libaaa.so.2.5", RTLD_NOW ); if ( !handle ) { printf("Failed t
我是一名优秀的程序员,十分优秀!