c# – NHibernate查询以获取具有与字符串部分匹配的属性的对象

我有一个具有以下属性的Person类:

public class Person
{
  public string LastName { get; set; }
  public string FirstName{ get; set; }
  public string SecondName { get; set; }
  public string Position { get; set; }
}

向用户呈现搜索框,其中他们可以输入用空格分隔的字符串.任务是从DB查询所有具有与输入字符串的任何部分相等的属性的人(这些部分是由空格分割的子字符串).最简单的解决方案是OR所有可能的组合.但是,就我而言,它似乎并不正确.有更优雅的解决方案吗?
提前致谢.

最佳答案 我的答案从优雅意味着什么的定义开始?

有解决方案,如: –

>在数据库上创建一个计算列[FirstName] N”[Surname] N”[SecondName]等.然后你只需要根据计算列对OR字符串进行操作 – 这是优雅/更高效吗?我不太确定.
>创建FREETEXTABLE有关详细信息,请参阅MSDN.再次,您只需要对每个子字符串进行OR(基于SQL服务器FULL-TEXT sarch).
>在所有列上实现LUCENE索引,请参阅this.但是,需要考虑与数据库同步问题,并且您还需要学习新的框架,但搜索肯定是IMO更优雅.
>留下你得到的东西.

你决定哪一个取决于你,但1-3对你现在拥有的东西有不同的问题,这不是优雅的,但它很简单,很可能有效!

点赞