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

时间:2012-03-11 11:49:19

标签: 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所有可能的组合。但是,就我而言,它似乎并不正确。有更优雅的解决方案吗? 提前谢谢。

1 个答案:

答案 0 :(得分:2)

我的答案从What does elegant mean?

的定义开始

有以下解决方案: -

  1. 在数据库上创建一个计算列[FirstName] + N''+ [Surname] + N''+ [SecondName]等。然后你只需OR基于计算列的子串 - 是这优雅/更高效?我不太确定。
  2. 创建FREETEXTABLE有关详细信息,请参阅MSDN。再次,您只需要针对每个子字符串OR(基于SQL服务器FULL-TEXT sarch)。
  3. 在所有列上实施LUCENE索引,请参阅this。然而,需要考虑同步问题与数据库,你还需要学习一个新的框架,但搜索肯定是IMO更优雅。
  4. 留下你得到的东西。
  5. 你决定哪一个取决于你,但1-3对你目前拥有的东西有不同的问题,这不是优雅的,但它很简单,很可能有效!