NHibernate Expression.Like标准在两个领域
我有一个Nhibernate对象,它具有属性Firstname和Surname,并且我希望能够在两个字段(Firstname +“”+ Surname)上查询; 例如,如果搜索项是“John Doe”,那么当John和Doe处于独立字段时,这将匹配。
我怎样才能做到这一点? 谢谢!
所以我最终与:
.Add(Restrictions.Like(Projections.SqlFunction("concat",
        NHibernateUtil.String,
        Projections.Property("Firstname"),
        Projections.Constant(" "),
        Projections.Property("Surname")),
    searchString, MatchMode.Anywhere))
这似乎工作,因为我需要它。
string firstName = "John";
string lastName = "Doe";
例如,使用LINQ:
Session.Query<User>()
       .Where(u => u.FirstName == firstName || u.Surname == lastName)
       .ToList();
你可以用QueryOver来完成它,它看起来几乎相同:
Session.QueryOver<User>()
       .Where(u => u.FirstName == firstName || u.Surname == lastName)
       .List();
更新:我错过了这个问题的重点。
那这个呢:
var name = "John Doe";
Session.Query<User>()
       .Where(u => name.Contains(u.FirstName) || name.Contains(u.Surname))
       .ToList();
