栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

MyBatis框架

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

MyBatis框架

一、MyBatis是什么

  MyBatis是一个基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。

  mybatis通过xml或注解的方式将要执行的各种 statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句。

  最后mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc 进行了封装,屏蔽了jdbc api 底层访问细节,使我们不用与jdbc api 打交道,就可以完成对数据库的持久化操作。

二、开发步骤 1、添加MyBatis的坐标

在pom.xml中导入驱动:

  
            org.mybatis
            mybatis
            3.4.6
   
2、编写映射文件

在编写映射文件的前提下先建立数据库表和实体类,映射文件主要描述的是SQL语句。

动态SQL语句

  Mybatis 的映射文件中,前面我们的 SQL 都是比较简单的,有些时候业务逻辑复杂时,我们的 SQL是动态变化的,此时在前面的学习中我们的 SQL 就不能满足要求了。

常用的标签:

标签名作用
< select>查询
< insert>插入
< update>修改
< delete>删除
< where>where条件
< if>if判断
< foreach>循环
< sql>sql片段抽取

  Sql 中可将重复的 sql 提取出来,使用时用 include 引用即可,最终达到 sql 重用的目的

< foreach>标签用于遍历集合,它的属性:

	collection:代表要遍历的集合元素,注意编写时不要写#{}
	open:代表语句的开始部分
	close:代表结束部分
	item:代表遍历集合的每个元素,生成的变量名
	sperator:代表分隔符

案例:


    
    select * from user
    
    
    


3、编写核心文件

案例:



    
    

    
    
        
    

    
    
        
            
            
                
                
                
                
            
        
    

    
    
        
    

核心文件中的标签: environments标签


transactionManager事务管理器,类型有两种:

1、JDBC:这个配置就是直接使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。

2、MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如 JEE 应用服务器的上下文)。
 默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将 closeConnection 属性设置为 
false 来阻止它默认的关闭行为。

dataSource数据源类型有三种:

1、UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。

2、POOLED:这种数据源的实现利用“池”的概念将 JDBC 连接对象组织起来。

3、JNDI:这个数据源的实现是为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个 JNDI 上下文的引用。
mappers标签
  
    
        
    

该标签的作用是加载映射的,加载方式有

Properties标签

  实际开发中,习惯将数据源的配置信息单独抽取成一个properties文件,该标签可以加载额外配置的properties文件

typeAliases标签

typeHandlers标签
由于Java 类型和数据库的 JDBC 类型不是一一对应的, 所以我们把 Java 对象转换为数据库的值,和把数据库的值转换成 Java 对象,需要经过 一定的转换,这两个方向的转换就要用到 TypeHandler。

  无论是 MyBatis 在预处理语句(PreparedStatement)中设置一个参数时,还是从结果集中取出一个值时, 都会用类型处理器将获取的值以合适的方式转换成 Java 类型。

开发步骤:

①定义转换类继承类BaseTypeHandler
②覆盖4个未实现的方法,其中setNonNullParameter为java程序设置数据到数据库的回调方法,getNullableResult为查询时 mysql的字符串类型转换成 java的Type类型的方法
③在MyBatis核心配置文件中进行注册
plugins标签(插件标签)
MyBatis可以使用第三方的插件来对功能进行扩展,分页助手PageHelper是将分页的复杂操作进行封装,使用简单的方式即可获得分页的相关数据

开发步骤:
①导入通用PageHelper的坐标
②在mybatis核心配置文件中配置PageHelper插件
③测试分页数据获取

三、MyBatis的相应API

SqlSession工厂构建器SqlSessionFactoryBuilder:

SqlSession工厂对象SqlSessionFactory:


SqlSession会话对象
  SqlSession 实例在 MyBatis 中是非常强大的一个类。在这里你会看到所有执行语句、提交或回滚事务和获取映射器实例的方法。

四、MyBatis的Dao层实现 传统开发方式

1、编写UserDao接口

2、编写UserDaoImpl实现

3、测试传统方式

代理开发方式

  采用 Mybatis 的代理开发方式实现 DAO 层的开发,Mapper 接口开发方法只需要程序员编写Mapper 接口(相当于Dao 接口),由Mybatis 框架根据接口定义创建接口的动态代理对象,代理对象的方法体同上边Dao接口实现类方法。

Mapper 接口开发需要遵循以下规范:

编写UserMapper接口:

测试代理方式

五、MyBatis的多表操作

六、MyBatis注解开发

常用注解:

注解说明
@Insert实现新增
@Update实现更新
@Delete实现删除
@Select实现查询
@Result实现结果及封装
@Results可以与@Result 一起使用,封装多个结果集
@One实现一对一结果集封装
@Many实现一对多结果集封装

MyBatis的注解实现复杂映射开发:

  实现复杂关系映射之前我们可以在映射文件中通过配置来实现,使用注解开发后,我们可以使用@Results注解,@Result注解,@One注解,@Many注解组合完成复杂关系的配置

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/881247.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号