minidao 简介及特征
minidao 是一款超轻量的java持久层框架,具备mybatis一样的sql能力: 支持sql分离、支持标签、支持注解。minidao产生的初衷是为了解决hibernate项目对复杂sql支持能力,具备mybatis一样的灵活性,同时支持事务同步。
具有以下特征:
- o/r mapping不用设置xml,零配置便于维护
- 不需要了解jdbc的知识
- sql语句和java代码的分离
- 只需接口定义,无需接口实现
- sql支持脚本语言(强大脚本语言,freemarker语法)
- 支持与hibernate轻量级无缝集成
- 支持自动事务处理和手动事务处理
- 性能优于mybatis
- 比mybatis更简单易用
- sql 支持注解方式
- sql 支持独立文件方式,sql文件的命名规则: 类名_方法名; sql文件更容易定位,项目越大优势越明显
- sql标签采用
minidao产生的初衷?
采用hibernate的j2ee项目都有一个痛病,针对复杂业务sql能力不足,sql不好优化和也无法分离。 这个时候大家就想到集成mybatis,但是一个项目既用hibernate又用mybatis,显得很重事务也不好控制。大家常规的做法是采用springjdbc来实现原生sql编写,但是同样也存在问题,sql无法分离也没有逻辑标签能力。 所以为了解决这个痛病,jeecg针对springjdbc freemarker做了封装,出了这么一个轻量级持久层,可以让hiberate拥有mybatis一样sql灵活能力,同时支持事务统一、sql标签能力。
版本升级日志
- 1. 简化pom.xml配置,删掉不需要的依赖
- 2. 日志重写,统一采用接口实现
- 3. 升级freemarker版本
- 4. 提供事务demo,注解方式
- 5. 规范化代码,日志打印规范化,提高效率和通用性
源码下载
- 源 码:
- 论 坛:
- 文 档:
- qq交流群:① 325978980
源码解读:
@minidao public interface employeedao { public list
sql定义
select * from employee where 1=1 <#if employee.age ?exists> and age = :employee.age <#if employee.name ?exists> and name = :employee.name <#if employee.empno ?exists> and empno = :employee.empno