数据库
首页 > 数据库> > mysql-查询与两列字符串匹配的数据

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,ruby-on-rails,mysql
来源: https://codeday.me/bug/20191210/2104404.html