内容简介: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); // 输出作者名字
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Where Wizards Stay Up Late
Katie Hafner / Simon & Schuster / 1998-1-21 / USD 16.00
Twenty five years ago, it didn't exist. Today, twenty million people worldwide are surfing the Net. "Where Wizards Stay Up Late" is the exciting story of the pioneers responsible for creating the most......一起来看看 《Where Wizards Stay Up Late》 这本书的介绍吧!