连续行比较

在本教程中,我们将介绍如何使用自连接技术来比较同一个表中的连续行。

假设您有一个名为inventory的表,其中包含由CREATE TABLE语句定义的结构,如下所示:

USE testdb;
CREATE TABLE inventory(
  id INT AUTO_INCREMENT PRIMARY KEY,
  counted_date date NOT NULL,
  item_no VARCHAR(20) NOT NULL,
  qty int(11) NOT NULL
);

在库存(inventory)表中:

  • id是自动增量列。

  • count_date是计数日期。

  • item_no是发布到广告资源的商品代码。

  • qty是库存中累计的现货数量。

以下是inventory表的示例数据:

INSERT INTO inventory(counted_date,item_no,qty)
VALUES ('2017-10-01','A',20),
    ('2017-10-01','A',30),
    ('2017-10-01','A',45),
    ('2017-10-01','A',80),
    ('2017-10-01','A',100);

如果想知道每个物品每天收到的物品数量,需要将特定日期的现有数量与前一天进行比较。

换句话说,在inventory表中,需要将一行与其连续行进行比较以找出差异。

在MySQL中,可以使用自连接技术来比较连续的行,如以下查询:

SELECT 
    g1.item_no,
    g1.counted_date from_date,
    g2.counted_date to_date,
    (g2.qty - g1.qty) AS receipt_qty
FROM
    inventory g1
        INNER JOIN
    inventory g2 ON g2.id = g1.id + 1
WHERE
    g1.item_no = 'A';

执行上面查询语句,得到以下结果 -

+---------+------------+------------+-------------+
| item_no | from_date  | to_date    | receipt_qty |
+---------+------------+------------+-------------+
| A       | 2017-10-01 | 2017-10-01 |          10 |
| A       | 2017-10-01 | 2017-10-01 |          15 |
| A       | 2017-10-01 | 2017-10-01 |          35 |
| A       | 2017-10-01 | 2017-10-01 |          20 |
+---------+------------+------------+-------------+
4 rows in set

INNER JOIN子句g2.id = g1.id + 1中的条件允许您将当前行与inventory表中的下一行进行比较,当然,假设id列中没有间隙。

如果无法避免差距,您可以创建一个附加列,例如seq来维护行的顺序,以便应用此技术。

在本教程中,您已经学会了如何使用自连接技术来比较同一个表中的连续行。

Last updated