Entity for D 2.5.0 发布,D 语言 ORM 实现

栏目: 软件资讯 · 发布时间: 5年前

内容简介:Entity 是 D语言( DLang )数据库操作 ORM 框架,设计参照 javax JPA 实现,具有很好的扩展性和规范性,数据库驱动依赖 HuntLabs 开发的原生数据库驱动库 hunt-database 。 特性 实现了完整的 CriteriaQuery 支持 ...

Entity 是 D语言( DLang )数据库操作 ORM 框架,设计参照 javax JPA 实现,具有很好的扩展性和规范性,数据库驱动依赖 HuntLabs 开发的原生数据库驱动库 hunt-database

特性

  1. 实现了完整的 CriteriaQuery 支持

  2. 标准化 Repository 使用封装

  3. 完全对象化查询,不用考虑底层数据库驱动

  4. 实现 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); // 输出作者名字
}

 


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Web标准设计

Web标准设计

刘杰(嗷嗷) / 清华大学出版社 / 2009-1 / 75.00元

一扇经常开启的门的铰链不需要润滑油。 一条湍急的河流不会变得污浊。 无论是声音还是想法都不可能在真空中传播。 Web标准如果不用就会腐朽。 这世界真奇妙! 专题页面:http://www.aoao.org.cn/book/web-standards-design/一起来看看 《Web标准设计》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具