开源项目 ransack 搜索条件

chaz1942 · 2016年04月06日 · 最后由 liwen_zhang 回复于 2016年11月15日 · 3345 次阅读

前几天做 ransack 模糊搜索时,关于查询条件发现网上没有太多的解释,于是下载源码搜索了一下,找到了所有的搜索条件,现在发出啦与大家分享一下,希望对大家有帮助。关于 ransack 的介绍 github 上有就不赘述了https://github.com/activerecord-hackery/ransack

eq: "等于"
eq_any: "等于任意值"
eq_all: "等于所有值"
not_eq: "不等于"
not_eq_any: "不等于任意值"
not_eq_all: "不等于所有值"
matches: "符合"
matches_any: "符合任意条件"
matches_all: "符合所有条件"
does_not_match: "不符合"
does_not_match_any: "符合任意条件"
does_not_match_all: "不符合所有条件"
lt: "小于"
lt_any: "小于任意一个值"
lt_all: "小于所有值"
lteq: "小于等于"
lteq_any: "小于等于任意一个值"
lteq_all: "小于等于所有值"
gt: "大于"
gt_any: "大于任意一个值"
gt_all: "大于所有值"
gteq: "大于等于"
gteq_any: "大于等于任意一个值"
gteq_all: "大于等于所有值"
in: "被包含"
in_any: "被任意值包含"
in_all: "被所有值包含"
not_in: "不被包含"
not_in_any: "不被任意值包含"
not_in_all: "不被所有值包含"
cont: "包含"
cont_any: "包含任意一个值"
cont_all: "包含所有值"
not_cont: "不包含"
not_cont_any: "不包含任意一个值"
not_cont_all: "不包含所有值"
start: "以改值开始"
start_any: "以任意一个值开始"
start_all: "以所有值开始"
not_start: "不以改值开始"
not_start_any: "不以任意一个值开始"
not_start_all: "不以所有值开始"
end: "以改值结尾"
end_any: "以任意一个值结尾"
end_all: "以所有值结尾"
not_end: "不以改值结尾"
not_end_any: "不以任意一个值结尾"
not_end_all: "不以所有值结尾"
'true': "等于true"
'false': "等于false"
present: "有值"
blank: "为空"
'null': "是null"
not_null: "不是null"

不错的分享,之前用的时候也是对照着源码来写模板。

赞 收藏一下. 多谢楼主.

@zouchaoge 是的,之前找不到详细的介绍,不过看源码确实很有帮助

正好需要,谢谢了!

请问使用 ransack 能完成类似:@orders = Order.where("state = ? OR state= ? AND user_id = ?", "on_sell","off_sell",current_user_id) 的查询功能吗? 我找了好久都没发现,也没有思路,求指教

#5 楼 @SomeOneToken

Order.search(state_eq:'on_sell', state_eq: 'off_sell', m: 'or').result.where(user_id: current_user_id)

OR

Order.search(state_in:['on_sell', 'off_sell'], user_id_eq: current_user_id).result

OR

Order.where(state:['on_sell', 'off_sell'], user_id: current_user_id)
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册