Mybatis_01

Mybatis

  • 简介与HelloWorld
  • 全局配置文件
  • 映射文件
  • 动态SQL
  • 缓存机制
  • Spring整合
  • 逆向工程

一、简介与HelloWorld

1.1 简介

MyBatis是一个半自动化的持久化层框架

JDBC
SQL夹在Java代码块里,耦合度高导致硬编码内伤
维护不易且实际开发需求中sql是有变化,频繁修改的情况多见

Hibernate和JPA
长难复杂SQL,对于Hibernate而言处理也不容易
内部自动生产的SQL,不容易做特殊优化。
基于全映射的全自动框架,大量字段的POJO进行部分映射时比较困难。导致数据库性能下降。

对开发人员而言,核心sql还是需要自己优化

sql和java编码分开,功能边界清晰,一个专注业务、一个专注数据。

1.2 HelloWorld

1、创建MyBatis全局配置文件
2、创建SQL映射文件

根据全局配置文件,利用SqlSessionFactoryBuilder创建SqlSessionFactory

使用SqlSessionFactory获取sqlSession对象。一个SqlSession对象代表和数据库的一次会话。

SqlSession
SqlSession 的实例不是线程安全的,因此是不能被共享的。

SqlSession每次使用完成后需要正确关闭,这个关闭操作是必须的

SqlSession可以直接调用方法的id进行数据库操作,但是我们一般还是推荐使用SqlSession获取到Dao接口的代理类,执行代理对象的方法,可以更安全的进行类型检查操作

二、全局配置文件

2.1 properties

在这里插入图片描述
如果属性在不只一个地方进行了配置,那么 MyBatis 将按照下面的顺序来加载:
在 properties 元素体内指定的属性首先被读取。
然后根据 properties 元素中的 resource 属性读取类路径下属性文件或根据 url 属性指定的路径读取属性文件,并覆盖已读取的同名属性。
最后读取作为方法参数传递的属性,并覆盖已读取的同名属性。

2.2 settings

这是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为。
在这里插入图片描述

2.3 typeAliases别名处理器

2.4 typeHandlers类型处理器

2.5 plugins插件

插件是MyBatis提供的一个非常强大的机制,我们可以通过插件来修改MyBatis的一些核心行为。插件通过动态代理机制,可以介入四大对象的任何一个方法的执行。

2.6 environments环境

id:指定当前环境的唯一标识
transactionManager、和dataSource都必须有

在这里插入图片描述

2.7 transactionManager

2.8 transactionManager

2.9 mapper映射

mapper逐个注册SQL映射文件
在这里插入图片描述
或者使用批量注册
这种方式要求SQL映射文件名必须和接口名相同并且在同一目录下
在这里插入图片描述

三、映射文件

映射文件指导着MyBatis如何进行数据库增删改查,有着非常重要的意义

  • cache –命名空间的二级缓存配置
  • cache-ref – 其他命名空间缓存配置的引用
  • resultMap – 自定义结果集映射
  • parameterMap – 已废弃!老式风格的参数映射
  • sql –抽取可重用语句块
  • insert – 映射插入语句
  • update – 映射更新语句
  • delete – 映射删除语句
  • select – 映射查询语句

3.1 insert、update、delete元素

在这里插入图片描述
若数据库支持自动生成主键的字段(比如 MySQL 和 SQL Server),则可以设置 useGeneratedKeys=”true”,然后再把 keyProperty 设置到目标属性上。

而对于不支持自增型主键的数据库(例如 Oracle),则可以使用 selectKey 子元素:selectKey 元素将会首先运行,id 会被设置,然后插入语句会被调用

3.2 参数传递

  • 单个参数
    可以接受基本类型,对象类型,集合类型的值。这种情况MyBatis可直接使用这个参数,不需要经过任何处理。
  • 多个参数
    任意多个参数,都会被MyBatis重新包装成一个Map传入。Map的key是param1,param2,0,1…,值就是参数的值。
  • 命名参数
    为参数使用@Param起一个名字,MyBatis就会将这些参数封装进map中,key就是我们自己指定的名字
  • POJO
    当这些参数属于我们业务POJO时,我们直接传递POJO
  • Map
    我们也可以封装多个参数为map,直接传递

3.3 参数处理

参数也可以指定一个特殊的数据类型:

javaType 通常可以从参数对象中来去确定
如果 null 被当作值来传递,对于所有可能为空的列,jdbcType 需要被设置
对于数值类型,还可以设置小数点后保留的位数:
mode 属性允许指定 IN,OUT 或 INOUT 参数。如果参数为 OUT 或 INOUT,参数对象属性的真实值将会被改变,就像在获取输出参数时所期望的那样。

参数位置支持的属性
javaType、jdbcType、mode、numericScale、
resultMap、typeHandler、jdbcTypeName、expression

实际上通常被设置的是:
可能为空的列名指定 jdbcType
#{key}:获取参数的值,预编译到SQL中。安全。
${key}:获取参数的值,拼接到SQL中。有SQL注入问题。ORDER BY ${name}

3.4 select元素

Select元素来定义查询操作。
Id:唯一标识符。
用来引用这条语句,需要和接口的方法名一致
parameterType:参数类型。
可以不传,MyBatis会根据TypeHandler自动推断
resultType:返回值类型。
别名或者全类名,如果返回的是集合,定义集合中元素的类型。不能和resultMap同时使用
在这里插入图片描述

3.5 自动映射

1、全局setting设置
autoMappingBehavior默认是PARTIAL,开启自动映射的功能。唯一的要求是列名和javaBean属性名一致
如果autoMappingBehavior设置为null则会取消自动映射
数据库字段命名规范,POJO属性符合驼峰命名法,如A_COLUMNaColumn,我们可以开启自动驼峰命名规则映射功能,mapUnderscoreToCamelCase=true。

2、自定义resultMap,实现高级结果集映射。

3.6 resultMap

  • constructor - 类在实例化时, 用来注入结果到构造方法中
  • idArg - ID 参数; 标记结果作为 ID 可以帮助提高整体效能
  • arg - 注入到构造方法的一个普通结果
  • id – 一个 ID 结果; 标记结果作为 ID 可以帮助提高整体效能
  • result – 注入到字段或 JavaBean 属性的普通结果
  • association – 一个复杂的类型关联;许多结果将包成这种类型
    嵌入结果映射 – 结果映射自身的关联,或者参考一个
  • collection – 复杂类型的集
    嵌入结果映射 – 结果映射自身的集,或者参考一个
  • discriminator – 使用结果值来决定使用哪个结果映射

3.7 联合查询

1. association

复杂对象映射
POJO中的属性可能会是一个对象
我们可以使用联合查询,并以级联属性的方式封装对象。
使用association标签定义对象的封装规则
在这里插入图片描述
select:调用目标的方法查询当前属性的值
column:将指定列的值传入目标方法

开启延迟加载和属性按需加载

在这里插入图片描述

2. Collection-集合类型&嵌套结果集
在这里插入图片描述
3. 分步查询

分步查询的时候通过column指定,将对应的列的数据传递过去,我们有时需要传递多列数据。
使用{key1=column1,key2=column2…}的形式

association或者collection标签的fetchType=eager/lazy可以覆盖全局的延迟加载策略,指定立即加载(eager)或者延迟加载(lazy)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值