前言git
为了让Dlang像 Java / PHP / C# 同样具备很是好的数据库操做体验,咱们了解了 PDO、JDBC、HIBERNATE、ADO.NET,最终发现你们的设计都不是很统一,只有 Java 最新的持久化标准 JPA 是真正的具备可移植性,因此咱们准备本身实现一套 JPA 机制,命名为 dlang-entity。github
分析数据库
分析的时候发现 dlang 官方没有任何标准的数据库操做接口,也就是像 PDO / JDBC / ADO.NET 这样的东东都不存在……架构
继续分析发现上层还有 SQL BUILDER ,最上层还有 Entity 的一系列管理,最终咱们把 ORM 分红了 4 个层,分别是 Database / DBAL / CriteriaQuery/ Entity性能
层次功能ui
难点分析设计
上面的架构是分层实现,可是对于功能来讲是从外而内,Database 和 Entity 是同步设计的,目前参考了 JPA 的接口设计,也认为是一种标准,可是存在的问题是语言之间的特性不一样,Java 在 JPA 的设计上使用了不少运行时注解特性,虽然设计简单可是性能确定是不理想,可是研究了 dlang 的方案后发现不少东西不能在运行时处理,由于 dlang 的编译时很是牛,虽然 dlang 这样的实现会让性能达到极致,可是也同时很大程度的增长了开发的复杂度。code
好比,参照 JPA 的设计用 dlang 能够这样:接口
class User { int id; string name; int age; int high; } class UserModel { User[] getUsers(String name, int age, int high) { CriteriaBuilder cb = em.getCriteriaBuilder(); CriteriaQuery query = cb.createQuery!User(); //from Root root = query.from(typeid(User)); //where Predicate p1 = cb.like(root.get("name"), "%" ~ name ~ "%"); Predicate p2 = cb.equal(root.get("age"), age); Predicate p3 = cb.equal(root.get("high"), high); Predicate p = cb.and(p1, cb.or(p2, p3)); query.where(p); User[] users; auto result = em.createQuery(query).getResult(); foreach(auto user; result) { users ~= user; } return users; } }
固然是否是行得通还有待验证,后续再持续更新本文章。 开发
未完待续!
~~~~~~~~~~ 2018.12.13 ~~~~~~~~~~~~
如今 hunt-entity 已经支持了完整的 JPA 实现,而且提供了 EQL 来对标 JPA 的 JPQL 来支持复杂查询,项目地址: