加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 帮助rails活动记录查询(如子句)

发布时间:2020-12-16 21:07:57 所属栏目:百科 来源:网络整理
导读:我希望我的代码做两件目前没有做的事情 @students = Student.where(["first_name = ? OR middle_name = ? OR last_name = ?",params[:query].split]) 工作. (它说我应该传递4个参数,但我希望用户能够键入单词并在每个字段上找到这些单词并返回任何匹配项) 实
我希望我的代码做两件目前没有做的事情
@students = Student.where(["first_name = ? OR middle_name = ? OR last_name = ?",params[:query].split])

>工作. (它说我应该传递4个参数,但我希望用户能够键入单词并在每个字段上找到这些单词并返回任何匹配项)
>实际上使用Like子句而不是刚性相等的子句.

请帮忙.

解决方法

这看起来像是一个更适合使用搜索而不是SQL的问题.你有没有考虑像 thinking sphinx或 act as ferret(solr可能是矫枉过正的).

…如果你必须在sql中这样做,你可以建立一个像这样的查询:

cols = ['first_name','last_name','middle_name']
query = 'John Smith'
sql_query = cols.map{|c| query.split.map{|q| "#{c} like '?'"}}.join(' OR ')
sql_query_array = query.split * cols.count
Student.where(sql_query,sql_query_array)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读