我有一个连接到服务器的客户端应用程序。服务器使用 hibernate 进行持久化和查询,因此它有一组带注释的 hibernate 对象用于持久化。
客户端向服务器发送 HQL 查询并获取响应。客户端有一组自动生成的对象,这些对象与服务器休眠对象匹配,用于查询结果和基本持久性。
我想支持使用 Linq 和 Hql 进行查询,因为它使查询类型安全且构建速度更快(HQL 字符串查询中不再有拼写错误)。我已经查看了以下内容,但我不知道如何让它们适合我所拥有的。
- NHibernate 的 Linq 提供程序 - 需要使用我没有的 NHibernate ISession 和 ISessionFactory
- LinqExtender - 需要对对象进行大量注释并扩展基本类型,过于侵入
我真正想要的是能够为我生成一个易于处理的结构来构建 HQL 查询的东西。我已经阅读了一位 C# 开发人员撰写的关于如何创建自定义提供程序的 15 页文章的大部分内容,这非常令人担忧,主要是因为表达式树的复杂性。
任何人都可以提出一种实施 Linq -> HQL 翻译的方法吗?也许是一个库,可以将表达式树清理成更 SQL/HQLish 的东西。
我想支持 select/from/where/group by/order by/joins。不太担心子查询。