我是 NHibernate 伟大世界的新手。我使用的是 2.0.1.GA 版。这是我的问题。我有一个表 Cars
,其中包含列 Manufacturer(nvarchar(50))
和一个主键 ID(int)
。我的 .NET 类是:
public class Car
{
public virtual int ID { get; set; }
public virtual string Manufacturer { get; set; }
}
现在,如果我想检索梅赛德斯制造的所有汽车,我必须输入:
using (var session = OpenSession())
{
var cars = session
.CreateCriteria(typeof(Car))
.Add(Restrictions.Like("Manufacturer", "Mercedes"))
.List();
// ...
}
我不喜欢我需要将属性名称指定为字符串的事实:( 是否有可能有一些对重构更友好的东西(这只是一个建议)?
var ms = session
.CreateCriteria<Car>()
.Add(c => c.Manufacturer, Restrictions.Like("Mercedes")
.List();
当前版本 (2.0.1.GA) 或 future 版本中是否有类似 thins 的内容?
最佳答案
正如 Google Ninja 所说,您可以使用 NHibernate.Linq 来完成。 查询将是:
session.Linq<Car>.Where(c => c.Manufacturer == "Mercedes").ToList()
如果有人最终来到这里并使用 NH3.0,则语法略有不同(感谢 Michael Mrozek 和 Mike 的建议):
session.Query<Car>.Where(c => c.Manufacturer == "Mercedes").ToList()
我使用了与 fluent-nhibernate 捆绑在一起的二进制文件适用于 2.0GA(我认为,不确定特定修订版)。
关于C# Lambda 表达式和 NHibernate,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/341239/