我有一个使用 Ransack gem 的应用程序,我正在将它从 Mysql 转换为 Postgres。
在排序列来自关联表且 distinct 选项设置为 true 的情况下,Postgres 会抛出此错误:
PG::InvalidColumnReference: ERROR: for SELECT DISTINCT, ORDER BY expressions must appear in select list
Ransack github 页面说,在这种情况下,“你只能靠你自己”。
什么是最好的 - 任何!- 处理这种情况的策略?
q = Contact.includes(:contact_type).search
q.sorts = ['contact_type_name asc']
q.result(distinct: true)
PG::InvalidColumnReference: ERROR: for SELECT DISTINCT, ORDER BY expressions must appear in select list
谢谢!