前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >minidao集Hibernate便捷和mybatis灵活的orm

minidao集Hibernate便捷和mybatis灵活的orm

作者头像
kl博主
发布2023-11-18 09:28:24
1330
发布2023-11-18 09:28:24
举报
文章被收录于专栏:kl的专栏kl的专栏

MiniDao

MiniDao简介及特征

MiniDao是jeecg项目的持久化解决方案,关于jeecg,可点击,MiniDao具备实体维护和SQL分离的两大优势,考虑了mybatis和hibernate的不足。 具有以下特征:

  • 1.O/R mapping不用设置xml,零配置便于维护
  • 2.不需要了解JDBC的知识
  • 3.SQL语句和java代码的分离
  • 4.可以自动生成SQL语句
  • 5.接口和实现分离,不用写持久层代码,用户只需写接口,以及某些接口方法对应的sql 它会通过AOP自动生成实现类
  • 6.支持自动事务处理和手动事务处理
  • 7.支持与hibernate轻量级无缝集成
  • 8.MiniDao吸收了Hibernate+mybatis的优势,支持实体维护和SQL分离
  • 9.SQL支持脚本语言

※实体的增删改查不需要写sql,支持SQL自动生成,以下实例来自官方,了解更多,可移步项目地址:点我 

接口和SQL文件对应目录

接口定义EmployeeDao.java

代码语言:javascript
复制
@MiniDao
public interface EmployeeDao {
 @Arguments("employee")
 public List getAllEmployees(Employee employee);

 @Arguments("empno")
 Employee getEmployee(String empno);

 @Arguments({"empno","name"})
 Map getMap(String empno,String name);

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

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

 @Arguments("employee")
 void insert(Employee employee);

}

SQL文件EmployeeDao_getAllEmployees.sql

代码语言:javascript
复制
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

MiniDao接口配置

代码语言:javascript
复制
  <!-- 注册MiniDao接口 -->
<bean class="org.jeecgframework.minidao.factory.MiniDaoBeanFactory">
    <property name="packagesToScan">
        <list>
            <value>examples.dao.*</value>
        </list>
    </property>
</bean>

测试代码

代码语言:javascript
复制
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();
    List list =  employeeDao.getAllEmployees(employee);
    for(Map mp:list){
        System.out.println(mp.get("id"));
        System.out.println(mp.get("name"));
        System.out.println(mp.get("empno"));
        System.out.println(mp.get("age"));
        System.out.println(mp.get("birthday"));
        System.out.println(mp.get("salary"));
    }
}
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-05-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • MiniDao
    • 接口和SQL文件对应目录
      • 接口定义EmployeeDao.java
        • SQL文件EmployeeDao_getAllEmployees.sql
          • MiniDao接口配置
            • 测试代码
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档