2013-01-04 141 views
2

我正在开发一个应用程序,我需要给用户提供搜索选项,就像用户输入'scienc'搜索功能应该得到名称科学的课程,或者如果在他们的描述科学像word一样,我的意思是说,如果用户输入半字查询应通过匹配字符序列获得完整的单词,但我不知道如何实现这一点,我在我的应用程序中使用实体框架。ASP.net从数据库搜索

还有一件事我需要从多个表中搜索。

在此先感谢。

+0

搜索ajax自动填充将解决您的问题 –

+0

关闭我的头顶,您可以使用SQL Server中的全文搜索功能http://msdn.microsoft.com/en-us/library/ms142571.aspx然后创建一个自定义存储过程并使用DbCommand来执行它并返回结果http://blogs.msdn.com/b/meek/archive/2008/03/26/ado-entity-framework-stored-procedure-customization.aspx – bUKaneer

+0

进一步@ RahulVasantraoKamble的答案尝试这个流行的工具[jquery用户界面自动完成](http://jqueryui.com/autocomplete/) – Stokedout

回答

0

我想你想实现自动完成,如果这样的话下面的代码将解决你的问题:

代码文件:

[WebMethod(EnableSession = true)] 
[ScriptMethod(ResponseFormat = ResponseFormat.Json)] 
public string[] GetPatientLastName(string prefix) 
{ 
    List<string> customers = new List<string>(); 
    using (SqlConnection conn = new SqlConnection()) 
    { 
     string connectionstring = CCMMUtility.GetCacheForWholeApplication(); 
     conn.ConnectionString = connectionstring; 
     using (SqlCommand cmd = new SqlCommand()) 
     { 
      cmd.CommandText = "select distinct top(10) PatientLastname from tblMessage where " + 
      "PatientLastname like '%'+ @SearchText + '%' order by PatientLastname"; 
      cmd.Parameters.AddWithValue("@SearchText", prefix); 
      cmd.Connection = conn; 
      conn.Open(); 
      using (SqlDataReader sdr = cmd.ExecuteReader()) 
      { 
       while (sdr.Read()) 
       { 
        customers.Add(string.Format("{0}", sdr["PatientLastname"])); 
       } 
      } 
      conn.Close(); 
     } 
     return customers.ToArray(); 
    } 
} 

jQuery代码:

$(document).ready(function() { 
     $('[ID$=txtPatientLastname]').live('keyup.autocomplete', function() { 

      $(this).autocomplete({ 
       source: function (request, response) { 
        $.ajax({ 
         url: '<%=ResolveUrl("~/Resources/WebService.asmx/GetPatientLastName") %>', 
         data: "{ 'prefix': '" + request.term + "'}", 
         dataType: "json", 
         type: "POST", 
         contentType: "application/json; charset=utf-8", 
         success: function (data) { 
          response($.map(data.d, function (item) { 
           return { 
            label: item.split('-')[0], 
            val: item.split('-')[1] 
           } 
          })) 
         }, 
         error: function (response) { 
          alert(response.responseText); 
         }, 
         failure: function (response) { 
          alert(response.responseText); 
         } 
        }); 
       }, 
       select: function (e, i) { 
       }, 
       minLength: 1 
      }); 
     }); 
}); 

希望这将满足您的要求。

+0

谢谢拉曼,但遗憾地说,我必须从4个表中搜索,如果我发现结果在2或3表匹配这个词我必须显示所有..帮助我,如果你有任何想法。 –

+0

逻辑将进入数据库的过程...这一步之后......您需要实现db查询中的连接以从多个表中获取数据.. –