php – mysql – 在所有日期出现的日期之间搜索
发布时间:2020-12-13 21:36:05 所属栏目:PHP教程 来源:网络整理
导读:我正在处理一些导入的数据,这些数据存储有关特定日期是否有“房间”可用的详细信息.每个房间都有一个单独的入口,可以使用它. | id | date | price |--------------------------------| 1 | 2010-08-04 | 45.00 | 用户可以搜索日期范围,搜索需要返回这两个日
我正在处理一些导入的数据,这些数据存储有关特定日期是否有“房间”可用的详细信息.每个房间都有一个单独的入口,可以使用它.
| id | date | price | -------------------------------- | 1 | 2010-08-04 | 45.00 | 用户可以搜索日期范围,搜索需要返回这两个日期之间可用的相关房间. 换句话说,使用sql查询来搜索: 其中日期> = 2010-08-04和日期< = 2010-08-09 这是不够的,因为这将在所选日期之间的所有房间带回所有房间,而不是所有相关日期可用的房间. 我正在考虑以某种方式使用临时日期表来交叉引用,该范围内的每个日期都有一个条目,但不确定实现此目的的最佳方式. 最终代码平台是PHP,我也在探索数据是否可以在代码中随后处理,但是如果可能的话,我希望保留所有内容. 任何提出的建议将不胜感激. 谢谢 解决方法
更新:我原来的答案与Quassnoi相同,但是已经晚了1分钟,所以我决定删除它并做一些不同的事情.此查询不假定(id,date)是唯一的.如果有多个条目,则选择最便宜的条目.此外,它还总计了可能也有用的总成本和回报.
SELECT id,SUM(price) FROM ( SELECT id,date,MIN(price) AS price FROM Table1 GROUP BY id,date) AS T1 WHERE `date` BETWEEN '2010-08-05' AND '2010-08-07' GROUP BY id HAVING COUNT(*) = DATEDIFF('2010-08-07','2010-08-05') + 1 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |