Я переносил некоторые из моих MySQL-запросов в PostgreSQL для использования Heroku. Большинство моих запросов работают нормально, но я сохраняю подобную повторяющуюся ошибку, когда я использую группу:
ОШИБКА: столбец "XYZ" должен появиться в предложении GROUP BY или использоваться в совокупная функция
Может ли кто-нибудь сказать мне, что я делаю неправильно?
MySQL, который работает на 100%:
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 "Доступно". * FROM "Доступные" INNER JOIN "номера" ON "номера".id = "гостинные".room_id ГДЕ (rooms.hotel_id = 5056 AND availableables.bookdate BETWEEN E'2009-10-21 ' И E'2009-10-23 ') ГРУППА BY Доступные. Bookdate ORDER BY availables.updated_at
Ruby-код, генерирующий SQL:
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 | price | spots | bookdate | room_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 rows in set