我在想你能不能帮我个忙。我需要搜索使用我的DB的2个字段,Cod +数字。我在一个专栏中展示了这一点,例如。cod +数字003,它显示ACE003,那么我如何在一个文本字段中搜索这两个选项。现在,如果您在字段中输入ACE003,则不会返回任何内容,但是如果您键入ACE,它当然可以工作。这是我的代码..
index.html
<%= text_field_tag :s_cod, params[:s_cod] %>
<% @items.each do |item| %>
<tr>
<td><%= item.cod + '%03d' % item.num.to_s %></td>
...
控制器
if (params[:s_cod] != nil) or (params[:s_rotulo] != nil) or (params[:s_den_cont] != nil) or (params[:s_marca] != nil)
@items = View_item.all.order("date_expired ASC").page(params[:page]).per(15).search(params[:s_cod], params[:s_rotulo], params[:s_den_cont], params[:s_marca])
你可以看到很多我用来搜索的字段。我必须使用一个字段来搜索cod + number。
模型
搜索部分
def self.search(s_codigo, s_rotulo, s_den_cont, s_marca)
where("cod ilike :s_c and rotulo ilike :s_r and den_cont ilike :s_d and marca ilike :s_m", s_c: "%#{s_cod}%", s_r: "%#{s_rotulo}%", s_d: "%#{s_den_cont}%", s_m: "%#{s_marca}%")
end
如何使用一个文本字段按cod + number进行搜索?提前感谢!
更新(已解决)
在我的postgress视图中,我使用
.concat(items.cod, to_char(items.num, 'fm000'::text)) AS codigo
发布于 2015-01-16 14:46:46
如果我没理解错的话,您需要查询这两列的连接值。
在MySQL中,使用CONCAT()函数,如
where("concat(code,number) LIKE :s_c",s_c: "%#{s_cod}%")
我相信PostgreSQL应该是类似的,但我不是百分之百熟悉它的语法
https://stackoverflow.com/questions/27985945
复制