mysql - 选择日期范围和列总和之间的日期

标签 mysql sql date range

我有以下表格:

假设第一个表代表客户对酒店的预订。

+------------+-----------+-----------+--------------+----------------+
| booking_id | client_id | room_type | arrival_date | departure_date |
+------------+-----------+-----------+--------------+----------------+
|          1 |         1 |         1 | 2016-05-30   | 2016-06-03     |
+------------+-----------+-----------+--------------+----------------+

第二张表包含不同类型房间的价格。价格因时间段而异。

+---------------+-----------+------------+------------+-------+
| room_price_id | room_type | start_date |  end_date  | price |
+---------------+-----------+------------+------------+-------+
|             1 |         1 | 2016-03-01 | 2016-05-31 |   150 |
|             2 |         1 | 2016-06-01 | 2016-08-31 |   200 |
+---------------+-----------+------------+------------+-------+

我的问题是:如果整个预订期间的价格不相同,我如何计算预订的总费用? (在我的例子中,总费用为 700)

我阅读了以下链接:MySQL: Select all dates between date range and get table data matching datesSelect data from date range between two dates ,但我不知道如何解决我的问题,因为表中的价格条目仅包含日期范围,而不是第一个链接中的明确日期。

最佳答案

您的问题的诀窍在于制定 bookingprices 表之间的连接条件。一旦解决了这个问题,一个简单的聚合就可以得到你想要的结果。只要给定价格范围内的任何点落在到达或离开日期的范围内,连接条件就应该为真。

然后,为了计算天数,我们使用到达日期或开始日期中的较大,以及出发日期或结束日期中的较小

SELECT
    b.booking_id,
    SUM((DATEDIFF(LEAST(b.departure_date, p.end_date),
             GREATEST(b.arrival_date, p.start_date)) + 1) * p.price) AS total
FROM booking b
INNER JOIN prices p
    ON b.room_type = p.room_type AND
       (p.start_date BETWEEN b.arrival_date AND b.departure_date OR
        p.end_date   BETWEEN b.arrival_date AND b.departure_date)
GROUP BY b.booking_id;

样本数据的输出是 900。这是正确的,因为:

2 days x 150 = 300
3 days x 200 = 600
       total = 900

此处演示:

SQLFiddle

here is another demo这突出了住宿与整个价格范围重叠的情况。

关于mysql - 选择日期范围和列总和之间的日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43446654/

相关文章:

sql - EXEC 使用数据库

linux - 如果日期字符串为 + 或 - 5 分钟,则

Javascript - 使用英国格式和 moment.js 创建新日期

php - Laravel 5.1 在数据库表的前面添加 MySQL 列

php - SUM重复的mysql php

mysql - 一个 `TEXT` 列可以容纳多少个多字节字符?

mysql - rails 2.3 : Replace record associations instead of delete

MYSQL : writing a query where a column is the result of a boolean expression

加入时MySQL语法错误

java - 如何检查日期数组与今天的日期是连续的?