- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经仔细阅读了这里关于这个主题的所有帖子,但我的问题有一个额外的问题,我需要获得每个房间的可用床位,因为它是一个旅馆,有些房间是共用的。
现在我已经尝试在 PHP 中这样做了,但后来意识到我什至没有考虑日期范围。所以现在我在想,因为我已经有一个查询来检索在给定日期范围内发生的所有预订,然后将检索到的房间及其床位与房间表进行比较,并仅显示未占用的房间及其床位。但我无法弄清楚如何在床周围工作,因为它们不是一个实体,只是每个房间的床总数。但是随后预订说预订的是房间里的哪张床..
这是我的表格
房间
预订
现在我用来检索所有预订房间及其床位的查询是
SELECT rooms_id, bed
FROM reservations
WHERE `to` > '2016-02-18' AND `from` < '2016-02-24'
第一个日期,如果我的输入变量是 $from,第二个日期是输入变量 $to,它不仅允许检索在 $from 和 $to 内开始预订的房间,还可以检索在该日期之前开始的所有预订范围内结束,在日期范围内开始并在日期范围之后结束,最后是在日期范围之前开始并在日期范围之后结束的预订。所以上面这个确切的查询将返回下表
但这就是我卡住的地方。我不知道如何匹配我拥有的数据以找到所有可用的房间,但也包括床。从“2016-02-18”到“2016-02-24”的日期范围内所需的表AVAILABLE ROOMS应该如下所示:
|||||||||||||||||||||||||||||||||
|| rooms_id || bed_number ||
||||||||||||||||||||||||||||
|| 1 || 1 ||
----------------------------
|| 1 || 2 ||
----------------------------
|| 2 || 5 ||
----------------------------
|| 2 || 6 ||
----------------------------
|| 2 || 7 ||
----------------------------
|| 2 || 8 ||
----------------------------
您可以在我展示它在我的应用程序中的外观的图片中看到这一点。在这两个日期之间唯一可用的房间和床位是豪华房及其床号 1 和床号 2 以及宿舍床位 5、6、7、8,因为 1-4 至少有一个预订所需的日期
我唯一的想法是使用 NOT IN,但这只有在我不关心床的情况下才有效,而且输出就在这里
SELECT *
FROM `rooms`
WHERE `id` NOT IN
(SELECT rooms_id FROM reservations WHERE `to` > '2016-02-18' AND `from` < '2016-02-24')
而不是我在上面“勾画”的内容
对于如何处理此问题的任何提示和想法,我将不胜感激。我的一部分担心这将归结为我没有将床视为实体并不得不这样做,即使我永远不会存储床上的任何类型的信息,例如它们的颜色、定位、质量、价格等...
回复@Paul-Spiegel
太棒了,但是有什么办法可以得到免费床位的数量而不是总数。因为那样的话,当这个人进行预订时,我必须将其分配给其中一张床。所以如果结果可能是
| room_id | title | beds_total | available_bed_nrs |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 1 | luxury room | 2 | 1, 2 |
| 2 | dorm room | 8 | 5, 6, 7, 8 |
代替
最佳答案
您可以通过以下查询获得一些空闲房间(以及预订的房间号):
set @from := '2016-02-18';
set @to := '2016-02-24';
set @beds := 1;
SELECT rm.id, rm.title, rm.beds,
rm.beds - IFNULL(rv.num_reserved_beds, 0) AS num_free_beds,
rv.reserved_bed_nrs
FROM rooms rm
LEFT JOIN (
SELECT rv.rooms_id,
COUNT(1) as num_reserved_beds,
GROUP_CONCAT(rv.bed) as reserved_bed_nrs
FROM reservations rv
WHERE rv.from < @to
AND rv.to > @from
GROUP BY rv.rooms_id
) rv ON rv.rooms_id = rm.id
HAVING num_free_beds >= @beds
您现在可以解析 reserved_bed_nrs
,遍历每个房间的所有床位并选择不在 reserved_bed_nrs
中的床位。
解释:
获取日期范围内(不包括)的所有床位预订:
SELECT *
FROM reservations r
WHERE r.from < @to
AND r.to > @from;
按房间分组,统计预订房间数,并将所有预订房间数存储在一个字符串字段中:
SELECT rv.rooms_id,
COUNT(1) as num_reserved_beds,
GROUP_CONCAT(rv.bed) as reserved_bed_nrs
FROM reservations rv
WHERE rv.from < @to
AND rv.to > @from
GROUP BY rv.rooms_id
用给定的结果加入(LEFT JOIN)rooms
,计算空闲床位的数量,并将其与您要预订的床位数量进行比较。
更新如何获得免费(未预订)床位:
如果您没有包含所有现有床位的表格,您将需要某种序列号。假设一个房间最多可以有 100 张床,您可以创建一个包含 100 个数字的 sequence
表:
CREATE TABLE `sequence` (
`nr` TINYINT(3) UNSIGNED NOT NULL,
PRIMARY KEY (`nr`)
) select d1.d*10 + d0.d + 1 as nr from
(select 0 d union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) d0,
(select 0 d union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) d1
现在可以通过交叉连接表 rooms
和 sequence
来列出所有现有床位:
SELECT *
FROM rooms rm
CROSS JOIN sequence seq
WHERE seq.nr <= rm.beds
要列出所有未预订床位,您可以将其与预订床位查询结合使用(选择在预订日期范围内未预订的所有床位):
SELECT *
FROM rooms rm
CROSS JOIN sequence seq
WHERE seq.nr <= rm.beds
AND (rm.id, seq.nr) NOT IN (
SELECT rv.rooms_id, rv.bed
FROM reservations rv
WHERE rv.from < '2016-02-24'
AND rv.to > '2016-02-18'
)
这也可以通过 NOT EXISTS
或排除 LEFT JOIN
来完成。
您也可以跳过 sequence
表的创建,使用创建代码作为子选择:
SELECT *
FROM rooms rm
CROSS JOIN (
select d1.d*10 + d0.d + 1 as nr
from
(select 0 d union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) d0,
(select 0 d union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) d1
) seq
WHERE seq.nr <= rm.beds
AND (rm.id, seq.nr) NOT IN (
SELECT rv.rooms_id, rv.bed
FROM reservations rv
WHERE rv.from < '2016-02-24'
AND rv.to > '2016-02-18'
)
关于php - 从数据库中检索给定日期范围内的可用房间及其床位,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35521876/
我有三个 td,并且正在尝试将每个内部的函数限制为仅该 td。我该怎么做呢?使用此代码,它会获取所有 3 个图像并将它们全部插入到 h2 之前: jQuery("td.frontpage_news")
这是所需的通用公式:if((b2-b1)=c1,True,False但是,我需要 b2-b1约等于 c1 , 在 5 内大约单位(在本例中为秒)。有没有可以处理这个的函数? 最佳答案 你也可以试试这个
我有三个整数,作为命令行参数传入后赋值给变量。我想验证每个整数都在 1-5 范围内。有没有一种方法可以在不使用如下所示的 if 语句的情况下在 Java 中完成此操作?我想避免这样做(注意伪代码):
检查某个变量 X 是否在某个变量 Z 的 n 个数字之内的最简洁方法是什么。n 是任意定义的数字(即 3)。 所以我想要 if (z {something} x){ // run code i
我的顶级 build.gradle (Gradle 2.2) 中有类似的东西 ext.repo = "https://my-artifactory-repo" buildscript { re
我只是在我的 jsp 页面中进行随机技巧和测试。我想使用 Attributes 将 request 范围对象存储在 session 范围对象中。存储后,当尝试从请求属性中提取值(存储在 session
我正在使用 Spring 。我有一个外部化属性文件。我正在按如下方式加载它。 现在我如何将 session 中的属性作为键值对保存? 我尝试编写一个扩展 ServletContextListene
我有以下范围: scope :billable, -> (range_start = nil, range_end = nil) { joins(:bids) .where("au
请看我的示例代码: var testObject = new SomeClass(); using (testObject) { //At this point how can the te
我目前在保持在 vector 范围内时遇到一些问题。 在下面的代码中,我试图检查正在检查的数字是否小于或等于它后面的数字 #include #include #include bool fun(
有人可以帮我解决下面的(简化的)代码吗?我试图从幻灯片事件函数中调用 doTheSlide() 函数。我对 JS 范围的理解仍然有点可疑。 实现这一目标的正确方法是什么?我收到此错误: Uncaugh
如何在 Swift 中检查时间是否在下午 6 点到晚上 11 点之间?我在使用 NSDateFormatter 时遇到了困难,我觉得一定有更简单的方法。 最佳答案 使用NSCalendar: let
我目前正在尝试创建一个 2D 横向滚动条,并且我目前有我的“世界”绘图(暂时是一个大白框),但我无法弄清楚世界地图的边缘与边缘之间的任何关系确保视口(viewport)始终完全被 map 覆盖。 我的
我正在学习李普曼,而且我只是在学习。我在这里尝试编写一个代码,该代码将返回 vector 中的最小元素。当我在 Codeblocks 中编译我的代码时,它说:“模板声明不能出现在 block 范围内”
我有三个日期对象。我该如何比较它们才能确定它们之间的相对差异。 oldDate = newDate() - 5; midDate = newDate() - 2.5; newDate = newDat
我需要检查对象“objCR”是否存在于当前范围内。我尝试使用以下代码。 if(objCR == null) alert("object is not defined"); 让我知道哪里错了。 最佳答案
如何检查 IP 地址是否属于私有(private)类别? if(isPrivateIPAddress(ipAddress)) { //do something } 如有
我正在开发一个 Firefox 插件,它可以转换用户通过用户选择突出显示的屏幕温度。转换后,用户选择将替换为 ID 为 alreadyconverted 的 span HTML 元素,其中包含原始温度
我正在开发一个邮资应用程序,该应用程序需要根据多个邮政编码范围检查整数邮政编码,并根据邮政编码匹配的范围返回不同的代码。 每个代码都有多个邮政编码范围。例如,如果邮政编码在 1000-2429、254
我正在使用 excel 范围进行连接:Set rng = Range("A1:A8")如果范围内的单元格之一为空,则会添加一个空格。 你如何阻止这个空间被添加? 最佳答案 假设您在那些非空单元格中有常
我是一名优秀的程序员,十分优秀!