mysql - 计算平均日期差

标签 mysql datediff

这是表的基本设置(仅存在相关列的 DDL)。 MySQL版本8.0.15

目的是显示订单之间的平均日期差异间隔。

    CREATE TABLE final (
    prim_id INT(11) NOT NULL AUTO_INCREMENT,
    order_ID INT(11) NOT NULL,
    cust_ID VARCHAR(45) NOT NULL,
    created_at DATETIME NOT NULL,
    item_name VARCHAR(255) NOT NULL,
    cust_name VARCHAR(255) NOT NULL,
    PRIMARY KEY (prim_id),
    COLLATE='latin1_swedish_ci'
    ENGINE=InnoDB
    AUTO_INCREMENT=145699

其他信息:

cust ID -> cust_name (one-to-many)
cust_ID -> order_ID (one-to-many)
order ID -> item_name (one-to-many)
order ID -> created_at (one-to-one)
prim_id -> *everything* (one-to-many)

我考虑过使用 min(created_at) 和 max(created_at) 但这将排除最旧和最新之间的所有订单。我需要一个更完善的解决方案。

最终结果应该是这样的:

有关所有订单之间的平均时间间隔的信息(不仅仅是最小和最大,因为经常有超过两次的时间),以天为单位,位于显示客户名称 (cust_name) 的列旁边。

最佳答案

如果我猜对了,您可能会使用子查询来获取上一个订单的日期。使用 datediff() 获取日期之间的差异,使用 avg() 获取差异的平均值。

SELECT f1.cust_id,
       avg(datediff(f1.created_at,
                    (SELECT f2.created_at
                            FROM final f2
                            WHERE f2.cust_id = f1.cust_id
                                  AND (f2.created_at < f1.created_at
                                        OR f2.created_at = f1.created_at
                                           AND f2.order_id < f1.order_id)
                            ORDER BY f2.created_at DESC,
                                     f2.order_id DESC
                            LIMIT 1)))
       FROM final f1
       GROUP BY f1.cust_id;
<小时/>

编辑:

如果一个订单 ID 可以有更多行,正如 KIKO Software 提到的,我们需要从一组不同的订单中执行 SELECT,例如:

SELECT f1.cust_id,
       avg(datediff(f1.created_at,
                    (SELECT f2.created_at
                            FROM (SELECT DISTINCT f3.cust_id,
                                                  f3.created_at,
                                                  f3.order_id
                                         FROM final f3) f2
                            WHERE f2.cust_id = f1.cust_id
                                  AND (f2.created_at < f1.created_at
                                        OR f2.created_at = f1.created_at
                                           AND f2.order_id < f1.order_id)
                            ORDER BY f2.created_at DESC,
                                     f2.order_id DESC
                            LIMIT 1)))
       FROM (SELECT DISTINCT f3.cust_id,
                             f3.created_at,
                             f3.order_id
                    FROM final f3) f1
       GROUP BY f1.cust_id;

如果订单有两行具有不同的客户 ID 或不同的创建时间戳,则此操作可能会失败。但在这种情况下,数据完全是垃圾,需要先纠正。

<小时/>

第二次编辑:

或者获取每个订单的最大创建时间戳(如果这些时间戳可能不同):

SELECT f1.cust_id,
       avg(datediff(f1.created_at,
                    (SELECT f2.created_at
                            FROM (SELECT max(f3.cust_id) cust_id,
                                         max(f3.created_at) created_at,
                                         f3.order_id
                                         FROM final f3
                                         GROUP BY f3.order_id) f2
                            WHERE f2.cust_id = f1.cust_id
                                  AND (f2.created_at < f1.created_at
                                        OR f2.created_at = f1.created_at
                                           AND f2.order_id < f1.order_id)
                            ORDER BY f2.created_at DESC,
                                     f2.order_id DESC
                            LIMIT 1)))
       FROM (SELECT max(f3.cust_id) cust_id,
                    max(f3.created_at) created_at,
                    f3.order_id
                    FROM final f3
                    GROUP BY f3.order_id) f1
       GROUP BY f1.cust_id;

关于mysql - 计算平均日期差,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55416105/

相关文章:

php - 为什么我无法在 IOS 应用程序中使用 NSURLConnection 使用 php 页面将记录重新添加到数据库?

cpanel cronjob中的Mysql计划事件

mysql - 在 MySQL 中使用 LIKE 运算符和逗号问题

mysql - 在 sql 结果中填充空日期的最直接方法是什么(在 mysql 或 perl 端)?

php - 在一段时间内使用 DateTime::diff() 与 mysql 记录进行操作

sql-server - T-SQL 周初返回不正确的日期

r - 通过ID计算时差

PHP 函数循环检查数据库中是否存在字符串

连接后,MySQL 查询仅过滤包含特定值的行

mysql - 不一致的 MySQL DATEDIFF 行为