Ruby 在 Rails 上像任何搜索一样搜索
Ruby on Rails search like any
我如何实现一种方法来搜索那些记录具有任何需要字段,其值 like
输入搜索关键字中的任何单词。
module Searchable
module_function
def search_like_any(attributes, keyword)
end
end
例如,假设我有一个模型 book
,它具有 name
、author
、description
属性,那么如果我这样搜索:
class Book < ApplicationRecord
include Searchable
end
Book.search_like_any([:name, :author, :description], "ruby on rails")
return 结果应该是名称或作者或描述包含“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
我如何实现一种方法来搜索那些记录具有任何需要字段,其值 like
输入搜索关键字中的任何单词。
module Searchable
module_function
def search_like_any(attributes, keyword)
end
end
例如,假设我有一个模型 book
,它具有 name
、author
、description
属性,那么如果我这样搜索:
class Book < ApplicationRecord
include Searchable
end
Book.search_like_any([:name, :author, :description], "ruby on rails")
return 结果应该是名称或作者或描述包含“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