Heroku を使用するために、MySQL クエリの一部を PostgreSQL に移行しています。ほとんどのクエリは正常に機能しますが、group by を使用すると同様のエラーが繰り返し発生します。
エラー: 列 "XYZ" は GROUP BY 句に指定するか、集計関数で使用する必要があります
誰かが私が間違っていることを教えてもらえますか?
100% 動作する MySQL:
SELECT `availables`.*
FROM `availables`
INNER JOIN `rooms` ON `rooms`.id = `availables`.room_id
WHERE (rooms.hotel_id = 5056 AND availables.bookdate BETWEEN '2009-11-22' AND '2009-11-24')
GROUP BY availables.bookdate
ORDER BY availables.updated_at
PostgreSQL エラー:
ActiveRecord::StatementInvalid: PGError: エラー: 列 "availables.id" は GROUP BY 句に表示されるか、集計関数で使用する必要があります:
SELECT "availables".* FROM "availables" INNER JOIN "rooms" ON "rooms". id = "availables".room_id WHERE (rooms.hotel_id = 5056 AND availables.bookdate BETWEEN E'2009-10-21' AND E'2009-10-23') GROUP BY availables.bookdate ORDER BY availables.updated_at
SQL を生成する Ruby コード:
expiration = Available.find(:all,
:joins => [ :room ],
:conditions => [ "rooms.hotel_id = ? AND availables.bookdate BETWEEN ? AND ?", hostel_id, date.to_s, (date+days-1).to_s ],
:group => 'availables.bookdate',
:order => 'availables.updated_at')
予想される出力 (動作中の MySQL クエリから):
+-----+----------+-------+------------+---------+---- -----------+---------------+ | | ID | 価格 | スポット | 予約日 | ルームID | created_at | updated_at | +-----+----------+-------+------------+---------+---- -----------+---------------+ | | 414 | 38.0 | 1 | 2009-11-22 | 1762年 | 2009-11-20... | 2009-11-20... | | | 415 | 38.0 | 1 | 2009-11-23 | 1762年 | 2009-11-20... | 2009-11-20... | | | 416 | 38.0 | 2 | 2009-11-24 | 1762年 | 2009-11-20... | 2009-11-20... | +-----+----------+-------+------------+---------+---- -----------+---------------+ 3列セット