我已经阅读了很多关于存储库模式实现的内容,但我仍然不知道应该如何实现实体投影查询?
例如,我有大而复杂的产品实体,但我只想显示产品的名称和它的 ID。我应该在哪里实施这个预测?在我的实体存储库或调用者代码中?
我已经阅读了很多关于存储库模式实现的内容,但我仍然不知道应该如何实现实体投影查询?
例如,我有大而复杂的产品实体,但我只想显示产品的名称和它的 ID。我应该在哪里实施这个预测?在我的实体存储库或调用者代码中?
我在存储库中执行此操作。
例如,我的 ProductRepository 界面如下所示:
interface IProductRepository
{
Product Get( int productId );
void Save( Product product );
ProductView FindProducts(string productNameSearch);
}
哪里ProductView
是 的简化表示Product
。(例如仅包含名称和 ID)。
获得 ProductView 的投影是必须抽象出来的东西,而存储库是它的好地方,恕我直言。
看看这里,你就会明白为什么这很困难。
http://lostechies.com/jimmybogard/2009/09/11/wither-the-repository/
我最近一直在梦想以下模式:
interface IRepository
{
Product FindByName(string name);
ProjectionType FindByName<ProjectionType>(string name,
Expression<Func<Product, ProjectionType>> selector);
// ...
}
使用此模式,您可以例如使用 LINQ 表达式和匿名类动态指定投影,如下所示:
var productView = repository.FindByName("foo",
p => new { p.SomeProperty, p.SomeOtherProperty } );
我认为这很整洁。使用 NHibernate.Linq,实现可能如下所示:
ProjectionType FindByName<ProjectionType>(string name, Expression<Func<Product, ProjectionType>> selector)
{
using(var session = this.sessionFactory.OpenSession()) {
return session.Linq<Product>()
.Where(p => p.Name.Equals(name))
.Select(selector)
.SingleOrDefault();
}
}
免责声明:当心上述代码中的错误或不良风格。甚至可能无法编译。这只是从我的头顶。但我认为这个想法应该很清楚。
有什么想法吗?