mysql - 房间预订查询

标签 mysql sql

我在编写 sql 以从表中获取可用房间时遇到问题。

下面给出了我的表结构。

Table Booking
ID | START_DATE | END_DATE


Table BookingRoom (Intermediate Table)
ID   | BOOKING_ID   |ROOM_ID

一个房间可以链接到多个预订,一个预订可以包含多个房间

Table Room
Contains the ID room

我已经尝试过此操作,但如果一个房间链接到不同日期的 2 个不同预订,则将仅使用第一个预订 ID 进行比较

SELECT DISTINCT r.ID FROM room AS r ,booking AS b,bookingroom AS br
 WHERE r.ID = br.ID_ROOM
 AND b.ID = br.ID_BOOKING
 AND (
           b.END_DATE < '05/14/2013'
        OR b.START_DATE > '05/15/2013'
     )

有人可以帮我编写 SQL 来获取入住日期和退房日期之间的可用房间吗?

最佳答案

如果您想要的只是整个所需日期范围内的可用房间列表,那么类似以下内容可能会起作用:

Select Room.Id
From Room
Where Room.Id Not In    (
                        Select RoomId
                        From BookingRoom
                            Join Booking
                                On Booking.Id = BookingRoom.BookingId
                        Where Booking.StartDate <= 'DesiredEndDate'
                            And Booking.EndDate >= 'DesiredStartDate'
                        )
Order By Room.Id

因此,使用原始示例,我们可能会得到:

Select Room.Id
From Room
Where Room.Id Not In    (
                        Select RoomId
                        From BookingRoom
                            Join Booking
                                On Booking.Id = BookingRoom.BookingId
                        Where Booking.StartDate <= '2013-05-15'
                            And Booking.EndDate >= '2013-05-14'
                        )
Order By Room.Id

关于mysql - 房间预订查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16554649/

相关文章:

php - 使用 PHP 和 MySQL 从数组插入多个值并将它们与单个值关联

sql - 展平嵌套数组并在雪花中聚合

java - 使用 POST 将 SQL 语句传递到 PHP 服务器

MySQL:用最后一个已知值填补空白

sql - 从 Oracle 表中获取值计数

mysql - 根据一个月中的某一天对数据进行分组和求和

php - 无法从 Android 连接到 PHP 中的数据库

c# - 相继执行多个请求时出现 MySql 异常

php - 从 Php 备份我的数据库时遇到问题

MySQL错误:#1238 - Variable 'innodb_lock_wait_timeout' is a read only variable