北京国炬信息技术有限公司

  • 首页
  • 产品方案
    • 低代码平台
    • 流程设计器
    • 微服务方案
    • 表单设计器
    • 大屏设计器
    • 报表设计器
    • 流程数据中台
    • 移动APP方案
  • 新闻动态
    • 公司动态
    • 技术博客
    • 学习视频
  • 关于我们
    • 公司简介
    • 发展历程
    • 公司荣誉
    • 联系我们
  • 人才招聘
首页 > 新闻动态 > 技术博客

MiniDao1.7.1 版本发布,轻量级Java持久化框架

作者:小编 发布时间:2021-03-28 点击数:

项目介绍

MiniDao 是一款轻量级JAVA持久层框架,基于 SpringJdbc + freemarker 实现,具备Mybatis一样的SQL分离和逻辑标签能力。Minidao产生的初衷是为了解决Hibernate项目,在复杂SQL具备Mybatis一样的灵活能力,同时支持事务同步。

当前版本:v1.7.1 | 2021-03-29

源码下载

  • https://github.com/zhangdaiscott/MiniDao
  • https://gitee.com/jeecg/minidao

升级日志

  • 升级spring版本到5.2.10.RELEASE
  • 升级freemarker版本到2.3.30
  • 提供代码生成器工具,快速生成dao和sql
  • 增加非持久化字段标记注解
  • 增加雪花分布式ID生成工具类
  • 提供springboot2快速集成starter

技术文档

  • 技术官网: http://www.jeecg.com
  • 技术文档: https://minidao.mydoc.io
  • 如何快速集成minidao

MiniDao特征

An powerful enhanced toolkit of SpringJdbc for simplify development

具有以下特征:

  • O/R mapping不用设置xml,零配置便于维护
  • 不需要了解JDBC的知识
  • SQL语句和java代码的分离
  • 只需接口定义,无需接口实现
  • SQL支持脚本语言(强大脚本语言,freemarker语法)
  • 支持与hibernate轻量级无缝集成
  • 支持自动事务处理和手动事务处理
  • 性能优于Mybatis
  • 比Mybatis更简单易用
  • SQL 支持注解方式
  • SQL 支持独立文件方式,SQL文件的命名规则: 类名_方法名; SQL文件更容易定位,方便后期维护,项目越大此优势越明显
  • SQL标签采用Freemarker的基本语法

代码体验

1. 接口定义[EmployeeDao.java]

    @MiniDao
    public interface EmployeeDao {
 
     @Arguments({ "employee"})
  @Sql("select * from employee")
  List<Map<String,Object>> getAll(Employee employee);
    
     @Sql("select * from employee where id = :id")
  Employee get(@Param("id") String id);
    
  @Sql("select * from employee where empno = :empno and  name = :name")
     Map getMap(@Param("empno")String empno,@Param("name")String name);

     @Sql("SELECT count(*) FROM employee")
     Integer getCount();

     int update(@Param("employee") Employee employee);

     void insert(@Param("employee") Employee employee);
  
  @ResultType(Employee.class)
  public MiniDaoPage<Employee> getAll(@Param("employee") Employee employee,@Param("page")  int page,@Param("rows") int rows);
   }

2. SQL文件[EmployeeDao_getAllEmployees.sql]

    SELECT * FROM employee where 1=1 
    <#if employee.age ?exists>
 and age = :employee.age
    </#if>
    <#if employee.name ?exists>
 and name = :employee.name
    </#if>
    <#if employee.empno ?exists>
 and empno = :employee.empno
    </#if>

3. 接口和SQL文件对应目录

MiniDao1.7.1 版本发布,轻量级Java持久化框架(图1)

4. 测试代码

    public class Client {
    public static void main(String args[]) {
  BeanFactory factory = new ClassPathXmlApplicationContext("applicationContext.xml");
  EmployeeDao employeeDao = (EmployeeDao) factory.getBean("employeeDao");
  Employee employee = new Employee();
  String id = UUID.randomUUID().toString().replaceAll("-", "").toUpperCase();
  employee.setId(id);
  employee.setEmpno("A001");
  employee.setSalary(new BigDecimal(5000));
  employee.setBirthday(new Date());
  employee.setName("scott");
  employee.setAge(25);
  //调用minidao方法插入
  employeeDao.insert(employee);
 }
    }
加入收藏
上一篇:暂无
下一篇:JeecgBoot Minio版本6.0.13升级到8.0.
返回列表

随便看看

  • 【敲敲云】免费的零代码产品 — 应用创建与设置
  • JeecgBoot 应用 Spring Authorization Server
  • JeecgBoot的前端Form升级为FormModel用法(支持 v-model 绑定)
  • JeecgBoot 单表数据导出多sheet实例
  • JeecgBoot与东方通TongWeb的高效部署方案
  • 【敲敲云】免费的零代码产品 — 应用用户角色与权限
  • JeecgBoot低代码平台—多租户SAAS解决方案,实现一键切换
  • 网友心得—运行jeecgboot-vue3项目可能出现的问题
  • 【敲敲云】免费的零代码产品,流程节点 — 获取多条记录实战
  • JeecgBoot Minio版本6.0.13升级到8.0.3修改方法

  • 公司产品
  • JeecgBoot低代码平台
  • 敲敲云零代码
  • 大屏设计器
  • 流程设计器
  • 表单设计器
  • 源码下载
  • JeecgBoot低代码平台
  • 积木报表平台
  • 移动开发平台
  • 微信管家平台
  • 更多信息
  • JEECG官方论坛
  • JEECG插件市场
  • 仪表盘设计器
  • 积木报表官网
  • 联系我们
  • 中国·北京·朝阳区科荟前街1号院奥林佳泰大厦9层
  • 商务QQ: 69893005、418799587
  • 商务热线: 010-64808099(5*8小时)
  • 项目外包: 18611788525(5*8小时)
  • 扫码关注我们
Copyright © 2015 北京国炬软件 All Rights Reserved Powered by JEECG 京ICP备2023027727号