微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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对你现在拥有的东西有不同的问题,这不是优雅的,但它很简单,很可能有效!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐