mysql-查询与两列字符串匹配的数据

假设我有带两列类别和名称的产品表.
现在,用户可以按类别或名称或类别和名称两者查找产品

例如,某产品的类别为计算机,名称为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计算机

上一篇:ruby-on-rails-是否有安装RMagick的简便方法?


下一篇:java-洛杉矶彭博终端的现代命令行编程