文档章节

D语言(Dlang)ORM - entity 架构

冰力
 冰力
发布于 2017/08/09 00:18
字数 660
阅读 268
收藏 2

前言

为了让Dlang像 Java / PHP / C# 一样具有非常好的数据库操作体验,我们了解了 PDO、JDBC、HIBERNATE、ADO.NET,最终发现大家的设计都不是很统一,只有 Java 最新的持久化标准 JPA 是真正的具有可移植性,所以我们准备自己实现一套 JPA 机制,命名为 dlang-entity。

分析

分析的时候发现 dlang 官方没有任何标准的数据库操作接口,也就是像 PDO / JDBC / ADO.NET 这样的东东都不存在……

继续分析发现上层还有 SQL BUILDER ,最上层还有 Entity 的一系列管理,最终我们把 ORM 分成了 4 个层,分别是 Database / DBAL / CriteriaQuery/ Entity

层次功能

  1. Database 负责基础的数据库访问,接收  SQL 语句,类似于 PDO、JDBC、ADO.NET;
  2. DBAL 负责实现 SQL BUILDER,依赖 Database;
  3. CriteriaQuery 是调用 DBAL 层,和 Entity 的实体进行关系绑定;
  4. Entity 见名之意就是实体,下面依赖 DBAL 和 CriteriaQuery。

难点分析

上面的架构是分层实现,但是对于功能来说是从外而内,Database 和 Entity 是同步设计的,目前参考了 JPA 的接口设计,也认为是一种标准,但是存在的问题是语言之间的特性不同,Java 在 JPA 的设计上使用了很多运行时注解特性,虽然设计简单但是性能肯定是不理想,但是研究了 dlang 的方案后发现很多东西不能在运行时处理,因为 dlang 的编译时非常牛,虽然 dlang 这样的实现会让性能达到极致,但是也同时很大程度的增加了开发的复杂度。

比如,参照 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 来支持复杂查询,项目地址:

https://github.com/huntlabs/hunt-entity

© 著作权归作者所有

冰力

冰力

粉丝 40
博文 9
码字总数 3983
作品 4
闵行
CTO(技术副总裁)
私信 提问
加载中

评论(4)

冰力
冰力 博主

引用来自“Alex-wxlang”的评论

好的,没想到您自己写了这么牛的框架,突然有点佩服,这就是我们找了很多年的东西!

@Alex-wxlang 我们有自己的一个团队,做喜欢的事儿
Alex-loongkylin
Alex-loongkylin
好的,没想到您自己写了这么牛的框架,突然有点佩服,这就是我们找了很多年的东西!
冰力
冰力 博主

引用来自“Alex-wxlang”的评论

这个怎么样了?老大!我是来跟你学D的

@Alex-wxlang 已经发布 hunt-entity 1.5.1 了,可用性还是不错的,具体可以看源码和事例代码 https://github.com/huntlabs/entity
Alex-loongkylin
Alex-loongkylin
这个怎么样了?老大!我是来跟你学D的
D 语言的 ORM 框架 - Entity

Entity 是 D 语言(dlang)数据库操作 ORM 框架,设计参照 javax JPA 实现,具有很好的扩展性和规范性,数据库驱动依赖 Huntlabs 开发的 database for dlang 。 特性: 实现了完整的 Criteria...

冰力
2018/05/14
499
2
D语言全栈 Web 框架 - hunt framework

Hunt framework Hunt framework 是一个由 HuntLabs 推出使用 Dlang 语言开发的全栈 web 框架,易用性和完整性都贴近于 Laravel / Django / Spring boot 等主流框架的设计,优势主要体现在部署...

匿名
01/29
998
1
Hunt framework 1.0.0 正式版,三年来最大更新

Hunt framework 通过三年的不断完善,HuntLabs 所有成员很高兴的对外宣布 hunt 1.0.0 正式版,经过了 0.4.x / 0.5.x / 0.7.x / 0.9.x / 0.10.x 的一些重要分支,我们改进了很多不方便使用的地...

冰力
2018/06/04
3.7K
27
LDC 1.9.0 发布,基于 LLVM 架构的 D 语言编译器

Kinke 代表LDC团队,很高兴地宣布LDC 1.9,这个版本的重点是: 编译器兼容 dlang 2.079.1 (引入了新的 -i 参数来支持最小D语言运行时); 支持 llvm 6,用于所有预构建包(Win32除外); `-...

冰力
2018/05/13
676
3
D 语言数据库驱动层 - Dbal

Dbal 是 HuntLabs 开发的D语言(dlang)数据库驱动层,类似 PHP 的 PDO、JAVA 的 JDBC,内置连接池支持。 目前支持的数据库驱动: PostgreSQL 8+ MySQL 5.1+ SQLite 3+ 示例代码 import std...

冰力
2018/05/14
422
0

没有更多内容

加载失败,请刷新页面

加载更多

JS 打印控制

JS 打印控制 var PrintStartString = "<!--打印开始标示符-->";//设置打印开始区域var PrintEndString = "<!--打印结束标示符-->";//设置打印结束区域var HtmlText = window.do......

DrChenXX
25分钟前
5
0
LevelDB:使用介绍

LevelDB 提供的接口其实很简单,下面举例进行简单说明。 安装 git clone https://github.com/google/leveldb cd leveldb mkdir -p build && cd build cmake -DCMAKE_BUILD_TYPE=Release .. ......

slagga
30分钟前
5
0
《JavaScript正则表达式迷你书》读书笔记

正则基础 常见简写形式 字符组 具体含义 记忆方式 \d 表示 [0-9]。表示是一位数字。 其英文是 digit(数字) \D 表示 [^0-9]。表示除数字外的任意字符。 \w 表示 [0-9a-zA-Z_]。表示数字、大小...

muzi131313
35分钟前
4
0
Git的反悔操作

概述 这次主要来讲讲Git的反悔操作,自己平时在写代码的过程中经常会出现想要弃用所有的改动或回滚到上一次commit的情况。Git上的反悔操作有reset、rebase、revert等,每个操作各有区别和对应...

duduYZ
36分钟前
3
0
实现双向绑定Proxy比defineproperty优劣如何?

前言 双向绑定其实已经是一个老掉牙的问题了,只要涉及到MVVM框架就不得不谈的知识点,但它毕竟是Vue的三要素之一. Vue三要素 响应式: 例如如何监听数据变化,其中的实现方法就是我们提到的双向...

寻找海蓝
48分钟前
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部