0

私はmysqlでテーブルを結合していますが、日付を保持するテーブルが1つあります。

table: cutoff

      date       roomid  
---------------------------  
    2012-11-03     25
    2012-11-04     25
    2012-11-05     25
    2012-11-06     25

そして、これが私のSQLクエリです。

SELECT t.RoomId, t.USD, t.MXN, i.Image, a.RoomName, a.RoomDesc, cu.date FROM Tarifas AS t 
INNER JOIN Images AS i ON i.RoomId = t.RoomId
INNER JOIN Availability AS a ON a.RoomId = t.RoomId 
INNER JOIN cutoff AS cu ON cu.roomid = t.RoomId AND cu.date NOT BETWEEN '$from' and '$to' 
WHERE t.Start <= '$from' AND t.End >= '$from' ORDER BY USD 

日付がカットオフテーブルにないすべての行を取得したいと思います。しかし、それは私に反対を与えています!どうしたらいいかわかりません。ここで助けていただければ幸いです。

TARIFAテーブルを追加するためのEIDT:

table: tarifas
RoomId      Start         End       USD       MXN
---------------------------------------------------
25        2012-11-01   2012-11-20   60.00    620.00
26        2012-11-01   2012-11-20   80.00    820.00
27        2012-11-01   2012-11-20   55.00    570.00
4

1 に答える 1

1

これを試してください(編集済み):

SELECT t.RoomId, t.USD, t.MXN, i.Image, a.RoomName, a.RoomDesc
FROM Tarifas AS t 
INNER JOIN Images AS i ON i.RoomId = t.RoomId
INNER JOIN Availability AS a ON a.RoomId = t.RoomId 
WHERE t.RoomID NOT IN
    (SELECT DISTINCT roomid FROM cutoff
    WHERE date BETWEEN '$from' AND '$to')
AND t.Start <= '$from' AND t.End >= '$from'
ORDER BY USD 
于 2012-10-27T21:53:24.040 に答える