• Wood,微型 Java ORM 框架(首次发版)


    Wood,微型 Java ORM 框架(支持:java sql,xml sql,annotation sql;事务;缓存;监控;等…),零依赖

    特点和理念:

    • 跨平台:可以嵌入到JVM脚本引擎(js, groovy, lua, python, ruby)及GraalVM支持的部分语言。
    • 很小巧:0.2Mb(且是功能完整,方案丰富;可极大简化数据库开发)。
    • 有个性:不喜欢反射(主打弱类型)、不喜欢配置(除了连接,不需要任何配置)。
    • 其它的:支持缓存控制和跨数据库事务。

    核心对象和功能:

    • 上下文:DbContext db
    • 四个接口:db.mapper(), db.table(), db.call(), db.sql()
    /** BaseMapper 用法 */
    //BaseMapper 接口
    db.mapperBase(User.class).selectById(1);
    
    //BaseMapper 接口,lambda 条件查询
    db.mapperBase(User.class).selectList(mq->mq
            .whereLt(User::getGroup,1)
            .andEq(User::getLabel,"T"));
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    /** Table用法 */
    //增::
    db.table("user").setEntity(user).insert();
    db.table("user").setMap(map).insert();
    db.table("user").setMap(map).insertAsCmd(); //构建查询命令(即查询语句)
    //删::
    db.table("user").whereEq("id",2).delete();
    //改::
    db.table("user").set("sex",1).whereEq("id",2).update();
    db.table("user").setInc("level",1).whereEq("id",2).update(); //字段自+1
    //查::
    db.table("user u")
      .innerJoin("user_ext e").onEq("u.id","e.user_id")
      .whereEq("u.id",1001)
      .selectItem("u.*,e.sex,e.label", User.class);
    db.table("user u")
      .innerJoin("user_ext e").onEq("u.id","e.user_id")
      .whereEq("u.id",1001)
      .selectAsCmd("u.*,e.sex,e.label"); //构建查询命令(即查询语句)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    
    
    DOCTYPE mapper PUBLIC "-//noear.org//DTD Mapper 3.0//EN" "http://noear.org/dtd/wood-mapper.dtd">
    <mapper namespace="wood_demo.xmlsql2"
            import="demo.model.*"
            baseMapper="UserModel">
        <sql id="getUser" return="UserModel" remarks="获取用户信息">
            SELECT * FROM user WHERE id = @{id:int}
        sql>
    mapper>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    项目地址:

    • https://gitee.com/noear/wood
    • https://github.com/noear/wood
  • 相关阅读:
    两化融合管理体系所有需要上传平台内容集合
    SQL注入漏洞(MSSQL注入)
    java计算机毕业设计教育辅导班信息网服务端源码+mysql数据库+系统+lw文档+部署
    kubernetes部署jenkins
    软件测试/测试开发/人工智能丨Python类型转换
    自定义RBAC(2)
    【云原生 · Kubernetes】KubeVirt热迁移
    adapter 模式
    Java设计模式01- 概览
    含免费次数的常用API接口
  • 原文地址:https://blog.csdn.net/cwzb/article/details/132916176