我有一个使用 Ransack gem 的应用程序,我正在将其从 Mysql 转换为 Postgres。
在排序列来自关联表并且 unique 选项设置为 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
Thanks!
有一个更简单的方法可以解决这个问题。使用 ActiveRecord 连接查询或选择查询来添加所需的列,例如:
q = Contact.search
q.sorts = ['contact_type_name asc']
q.result(distinct: true).
includes(:contact_type).
joins(:contact_type)
或者,如果您只想选择几列,您可以这样做:
q = Contact.search
q.sorts = ['contact_type_name asc']
q.result(distinct: true).
select('contacts.*, contact_type.name')
我做了一个拉取请求更新 Ransack 的自述文件。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)