我在pg生產(chǎn)模式下遇到此錯(cuò)誤,但在sqlite3開(kāi)發(fā)模式下工作正常。 ActiveRecord::StatementInvalid in ManagementController#indexPG::Error: ERROR: column "estates.id" must appear in the GROUP BY clause or be used in an aggregate functionLINE 1: SELECT "estates".* FROM "estates" WHERE "estates"."Mgmt" = ... ^: SELECT "estates".* FROM "estates" WHERE "estates"."Mgmt" = 'Mazzey' GROUP BY user_id@myestate = Estate.where(:Mgmt => current_user.Company).group(:user_id).all
3 回答

慕碼人2483693
TA貢獻(xiàn)1860條經(jīng)驗(yàn) 獲得超9個(gè)贊
我最近從MySQL遷移到PostgreSQL,并遇到了相同的問(wèn)題。僅供參考,我發(fā)現(xiàn)的最佳方法是按照此SO答案中的建議使用DISTINCT ON:
Ruby on Rails / ActiveRecord的優(yōu)雅PostgreSQL Group by
這將使您為所選列中與其他查詢(xún)條件匹配的每個(gè)唯一值獲得一條記錄:
MyModel.where(:some_col => value).select("DISTINCT ON (unique_col) *")
我更喜歡DISTINCT ON,因?yàn)槲胰匀豢梢垣@取行中的所有其他列值。僅DISTINCT只會(huì)返回該特定列的值。
- 3 回答
- 0 關(guān)注
- 2354 瀏覽
添加回答
舉報(bào)
0/150
提交
取消