簡體   English   中英

Ruby on Rails 搜索任何

[英]Ruby on Rails search like any

我如何實現一種可以搜索這些記錄的方法,該方法具有任何需要字段,其值與輸入搜索關鍵字中的任何單詞like

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

例如,假設我有一本 model book ,它具有nameauthordescription屬性,那么如果我這樣搜索:

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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM