[英]Ruby on Rails search like any
我如何實現一種可以搜索這些記錄的方法,該方法具有任何需要字段,其值與輸入搜索關鍵字中的任何單詞like
。
module Searchable
module_function
def search_like_any(attributes, keyword)
end
end
例如,假設我有一本 model book
,它具有name
、 author
、 description
屬性,那么如果我這樣搜索:
class Book < ApplicationRecord
include Searchable
end
Book.search_like_any([:name, :author, :description], "ruby on rails")
返回結果應該是具有名稱或作者或描述包含“ruby”或“on”或“rails”的書籍。
謝謝!
也許可以通過這種方式幫助您。
def self.search keyword
word = "%#{keyword}%"
("name LIKE ? OR auth LIKE ? OR description LIKE ?",word, word, word)
end
嘗試這個:
def search_like_any(attributes, keyword)
query_attrs = attributes.map { |attr| attr.to_s + ' LIKE :search_values'}.join(' OR ')
Book.where(query_attrs, search_values: keyword)
end
在這里, query_attrs
包含實際的查詢。
我找到了解決方案
module Searchable
module_function
def search_like_any(attributes, keyword)
return if attributes.blank? || keyword.blank?
values = keyword.split(/[,?.\s]/).uniq.reject(&:blank?)
matches = attributes.uniq.product(values).map do |(attr, value)|
arel_table[attr].matches("%#{value}%")
end
where matches.inject(:or)
end
end
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.