我在pg生產模式下遇到此錯誤,但在sqlite3開發模式下工作正常。 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貢獻1860條經驗 獲得超9個贊
我最近從MySQL遷移到PostgreSQL,并遇到了相同的問題。僅供參考,我發現的最佳方法是按照此SO答案中的建議使用DISTINCT ON:
Ruby on Rails / ActiveRecord的優雅PostgreSQL Group by
這將使您為所選列中與其他查詢條件匹配的每個唯一值獲得一條記錄:
MyModel.where(:some_col => value).select("DISTINCT ON (unique_col) *")
我更喜歡DISTINCT ON,因為我仍然可以獲取行中的所有其他列值。僅DISTINCT只會返回該特定列的值。
- 3 回答
- 0 關注
- 2309 瀏覽
添加回答
舉報
0/150
提交
取消