如何解决实体框架4.1和NHibernate的获取策略封装
|| 我创建了一个项目来测试NHibernate 3+与Entity Framework 4.1,将其包装在存储库中,使其可以使用接口等进行测试。 我不想在存储库之外公开任何一个ORM(我什至不公开IQueryables)。一切都应在该层中处理,直到我尝试以抽象方式处理获取之前,一切都很好。 Microsoft的添加急切加载的实现在Include函数上使用魔术字符串(yuck)或Linq表达式(yay)。它们的语法如下所示:IQueryableThing.Include(o => o.Person);
IQueryableThing.Include(o => o.Company.Contact);
IQueryableThing.Include(o => o.Orders.Select(p => p.LineItem.Cost);
第一个只会加载关联的人。 (父母)
第二个将加载关联的公司和每个公司的联系人。 (父母和祖父母)。
第三个将加载每个订单的所有关联订单,订单项和成本。
这是一个非常漂亮的实现。
NHibernate使用略有不同的方法。他们仍然使用Linq表达式,但是他们大量使用扩展方法(流利的方法)。
IQueryableThing.Fetch(o => o.Person);
IQueryableThing.Fetch(o => o.Company).ThenFetch(o => o.Contact);
IQueryableThing.FetchMany(o => o.Orders).ThenFetch(p => p.LineItem).ThenFetch(q => q.Cost);
(我不确定第三行的语法是否正确)
我可以将一个表达式列表封装在一个单独的类中,然后将这些表达式应用于该类中的IQueryable。因此,我需要做的是对Microsoft表达式语法进行标准化,然后通过遍历表达式树并重建每个表达式将其转换为NHibernate的语法。
这是真正棘手的部分。我必须维护特定的操作顺序才能为IQueryable调用正确的函数(必须以Fetch或FetchMany开头,其后每个都是\“ ThenFetch \”或\“ ThenFetchMany \”),这使我无法使用内置的ExpressionVisitor类。
编辑:
最后,我创建了一个表达式解析器,该解析器将对属性,集合进行任何级别的嵌套,然后对集合进行选择并生成一个表达式数组。不幸的是,内置的Fetch扩展方法没有采用LambdaExpression作为参数。
我目前停留的部分无法使用nHibernate内置的Fetch定义。看来我可能必须直接使用Remotion库的功能或注册自己的扩展方法,这些方法才能满足其解析器的要求。
时髦
解决方法
您是否尝试过使用
NHiberanteUtil.Initialize()
?我没有尝试做您正在做的事情,但我认为Initialize的工作方式类似于Include()
。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。