内容简介:Entity 是 D语言( DLang )数据库操作 ORM 框架,设计参照 javax JPA 实现,具有很好的扩展性和规范性,数据库驱动依赖 HuntLabs 开发的原生数据库驱动库 hunt-database 。 特性 实现了完整的 CriteriaQuery 支持 ...
Entity 是 D语言( DLang )数据库操作 ORM 框架,设计参照 javax JPA 实现,具有很好的扩展性和规范性,数据库驱动依赖 HuntLabs 开发的原生数据库驱动库 hunt-database 。
特性
-
实现了完整的 CriteriaQuery 支持
-
标准化 Repository 使用封装
-
完全对象化查询,不用考虑底层数据库驱动
-
实现 EQL(Entity Query Language)实现对象化 SQL 查询语言
支持的数据库
-
PostgreSQL 9.0+
-
MySQL 5.1+
本次主要更新内容
-
针对 EQL 进行增强
-
简化联表查询
-
重构数据库连接池部分
-
使用全新的 hunt-database
-
移除 libmysql / libpg 依赖,使用 DLang 重构数据库驱动层
-
修复部分已知问题
使用示例
用户模型
module app.model.User;
import hunt.entity;
@Table("users")
class User : Model
{
mixin MakeModel;
@AutoIncrement
@PrimaryKey
int id;
string name;
int created;
int updated;
}
文章模型
module app.model.Post;
import hunt.entity;
import app.model.User;
@Table("posts")
class Post : Model
{
mixin MakeModel;
@AutoIncrement
@PrimaryKey
int id;
string title;
int uid;
@JoinColumn("uid")
User user;
string content;
int status;
int created;
int updated;
}
使用 EQL 进行条件查询
// 通过 EQL 查询出 10 条文章,最新发表的排在前面
auto query = em.createQuery!(Post)("SELECT p FROM Post p WHERE p.status = 1 ORDER BY p.created DESC limit 10");
foreach (post; query.getResultList())
{
logDebug(post.title); // 打印文章标题
logDebug(post.user.name); // 输出作者名字
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Spring技术内幕
计文柯 / 机械工业出版社 / 2010-1-1 / 55.00元
内容简介: 本书是Spring领域的问鼎之作,由业界拥有10余年开发经验的资深Java专家亲自执笔!Java开发者社区和Spring开发者社区一致强烈推荐。 国内第一本基于Spring3.0的著作,从源代码的角度对Spring的内核和各个主要功能模块的架构、设计和实现原理进行了深入剖析。你不仅能从木书中参透Spring框架的优秀架构和设计思想,而且还能从Spring优雅的实现源码中一窥......一起来看看 《Spring技术内幕》 这本书的介绍吧!
HTML 压缩/解压工具
在线压缩/解压 HTML 代码
RGB转16进制工具
RGB HEX 互转工具