Ruby 在 Rails 上像任何搜索一样搜索

Ruby on Rails search like any

我如何实现一种方法来搜索那些记录具有任何需要字段,其值 like 输入搜索关键字中的任何单词。

module Searchable
  module_function
  def search_like_any(attributes, keyword)
  end
end

例如,假设我有一个模型 book,它具有 nameauthordescription 属性,那么如果我这样搜索:

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