我有一个要求,我很困惑如何编写查询.我是这家公司的新手,所以请帮助我
用户将选择以下日期:
例如:
fromDate:2013-08-02至日期:2013-09-03(YYYY-MM-DD)
id resort_id room_id Date1 Date2 price
5 35 45 2013-11-01 2013-11-30 3000.00
6 35 50 2013-07-25 2013-08-25 2000.00
7 35 541 2013-07-25 2013-08-25 4000.00
8 35 541 2013-08-26 2013-09-26 4000.00
现在我应该根据房间ID获得每个日期或价格总和的基于价格的结果
预期结果
id resort_id room_id Date1 Date2 price
6 35 50 2013-07-25 2013-08-25 2000.00
7 35 541 2013-07-25 2013-08-25 4000.00
8 35 541 2013-08-26 2013-09-26 4000.00
要么
id resort_id room_id price
6 35 50 2000.00
7 35 541 8000.00
解决方法:
试试这个查询
SELECT * FROM `rooms` WHERE "2013-08-02" between Date1 AND Date2 UNION
SELECT * FROM `rooms` WHERE "2013-09-03" BETWEEN Date1 AND Date2
它是一个单一的查询.将其分为两行以便于阅读.我很确定这个查询缺少一些东西.我需要一个更大的测试集来验证.这不会选择中间案例.
使用用户选择的日期更改第一个日期.