gpt4 book ai didi

ruby-on-rails - 太阳黑子通过电子邮件完全匹配搜索

转载 作者:数据小太阳 更新时间:2023-10-29 07:59:54 26 4
gpt4 key购买 nike

你好,今天我遇到了 Sunspot Solr 的这个问题,我无法让它用于精确的电子邮件搜索,我已经尝试了几个小时,最后我得出了这个解决方案,但它仍然不能作为精确匹配。

例如,我需要输入一封电子邮件 mushos32@yahoo.gr 并给我 1 个结果,如果我写 mushos32@yahoo.g 或除原始邮件之外的任何其他组合,它应该不会返回任何内容

我现在的代码是这样的

model
searchable do
text :email
String :email

end

Controller

 def search


@users = User.search do
keywords params[:query]
end.results

respond_to do |format|
format.html { render :action => "index" }
format.xml { render :xml => @users }
end
end

查看/用户/显示

  <%= form_tag search_users_path, :method => :get do %>
<p>
<%= text_field_tag :query, params[:search] %>
<%= submit_tag "Search" ,:email => nil %>

</p>
<% if @users.empty? %>
<p>Your search did not return any results. </p>
<% else %>
<% for user in @users %>
<tr>

<td><%= link_to user.name, user %> <%= link_to user.surname, user %></td>
<%= hidden_field_tag :direction, params[:direction] %>
<%= hidden_field_tag :sort, params[:sort] %>
<td><%= image_tag user.photo.url(:thumb) %></td>
<td><%= link_to "Connect", friendships_path(:friend_id => user), :method => :post %></td>
</tr>
<%end%>

你能帮帮我吗?我已经尝试重新索引,重新启动 solr 服务器,但似乎没有用

最佳答案

由于您只想在该字段上进行精确匹配,因此最简单的解决方案是将其设为字符串字段而不是文本字段:

class User < ActiveRecord::Base
searchable do
string :email
end
end

这样您就可以像这样在您的 Controller 中搜索用户:

def search
@users = User.search do
with(:email, params[:query])
end.results

respond_to do |format|
format.html { render :action => "index" }
format.xml { render :xml => @users }
end
end

参见 Sunspot documentation获取更多信息。

关于ruby-on-rails - 太阳黑子通过电子邮件完全匹配搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23661887/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com