假设我有带两列类别和名称的产品表.
现在,用户可以按类别或名称或类别和名称两者查找产品
例如,某产品的类别为计算机,名称为Dell.用户在搜索框“计算机”,“戴尔”或“戴尔计算机”或“戴尔计算机”中输入,都可以退回该产品
关于Activerecord查询有任何想法吗?
解决方法:
如果您使用的是mysql,则可以使用CONCAT来连接类别和名称,然后像平常一样进行LIKE查询
Product.where("LOWER(CONCAT(name, ' ', category)) LIKE :query OR LOWER(CONCAT(category, ' ', name)) LIKE :query", query: "%#{params[:query].downcase}%")
通过此查询,可以找到以下两种情况:Dell,计算机,Dell计算机或Dell计算机