检查范围是否与数据库重叠并合并

时间:2019-02-08 09:13:52

标签: mysql range overlapping coalesce

我不知道如何检查两个可以处理空值的范围(例如,范围A:null-空范围B:3-10)是否重叠。

在这种情况下,这两个范围重叠,因为在我的代码中null-null等于-∞和+∞,因此3-10位于-∞-+∞内。

问题是我需要构建一个查询,该查询返回我的表stock_rule中与我要创建的stock_rule记录重叠的所有记录。

如果计数大于零,则无法保存记录。

我正在尝试通过以下方式使用COALESCE函数(MySQL 8.0)实现这一目标:

COALESCE(rule.min_price, 0)<=COALESCE(:minPrice, rule.min_price,0) AND 
COALESCE(rule.max_price, 0)<=COALESCE(:minPrice, rule.max_price, 0) AND 
COALESCE(rule.min_price, 0)<=COALESCE(:maxPrice, rule.min_price,0) AND 
COALESCE(rule.max_price, 0)<=COALESCE(:maxPrice, rule.max_price, 0) AND 
COALESCE(:minPrice, 0)>=COALESCE(rule.min_price, :minPrice, 0) AND 
COALESCE(:maxPrice,0)<=COALESCE(rule.min_price, :maxPrice, 0) AND 
COALESCE(:minPrice,0)>=COALESCE(rule.max_price, :minPrice, 0) AND
COALESCE(:maxPrice, 0)<=COALESCE(rule.max_price, :maxPrice, 0)

1 个答案:

答案 0 :(得分:0)

我想类似的东西会起作用...

DROP TABLE ranges;

CREATE TABLE ranges
(id seriAL PRIMARY KEY
,range_start INT NULL
,range_end INT NULL
);

INSERT INTO ranges VALUES
(1,NULL,NULL),
(2,3,10),
(3,12,NULL),
(4,NULL,20),
(5,10,11);

  SELECT *
    FROM ranges x
    JOIN ranges y
      ON y.id <> x.id
     AND COALESCE(x.range_start,0) <= y.range_end
     AND COALESCE(x.range_end,(SELECT MAX(range_end) FROM ranges)) >= y.range_start;
+----+-------------+-----------+----+-------------+-----------+
| id | range_start | range_end | id | range_start | range_end |
+----+-------------+-----------+----+-------------+-----------+
|  1 |        NULL |      NULL |  2 |           3 |        10 |
|  4 |        NULL |        20 |  2 |           3 |        10 |
|  5 |          10 |        11 |  2 |           3 |        10 |
|  1 |        NULL |      NULL |  5 |          10 |        11 |
|  2 |           3 |        10 |  5 |          10 |        11 |
|  4 |        NULL |        20 |  5 |          10 |        11 |
+----+-------------+-----------+----+-------------+-----------+


mysql>