Mabtis知识点总结

一、MyBatis
1、MyBatis简介
1.1、MyBatis历史
1.2、MyBatis特性1.3、MyBatis下载
1.4、和其它持久化层技术对比
2、搭建MyBatis
2.1、开发环境
2.2、创建maven工程
①打包方式:jar
②引入依赖
2.3、创建MyBatis的核心配置文件
2.4、创建mapper接口
2.5、创建MyBatis的映射文件
2.6、通过junit测试功能
2.7、加入log4j日志功能
①加入依赖
②加入log4j的配置文件
3、核心配置文件详解
4、MyBatis的增删改查
4.1、新增
4.2、删除
4.3、修改
4.4、查询一个实体类对象
4.5、查询list集合
5、MyBatis获取参数值的两种方式
5.1、单个字面量类型的参数
5.2、多个字面量类型的参数
5.3、map集合类型的参数
5.4、实体类类型的参数
5.5、使用@Param标识参数
6、MyBatis的各种查询功能
6.1、查询一个实体类对象
6.2、查询一个list集合
6.3、查询单个数据
6.4、查询一条数据为map集合
6.5、查询多条数据为map集合
①方式一
②方式二
7、特殊SQL的执行
7.1、模糊查询
7.2、批量删除
7.3、动态设置表名
7.4、添加功能获取自增的主键
8、自定义映射resultMap
8.1、resultMap处理字段和属性的映射关系
8.2、多对一映射处理
8.2.1、级联方式处理映射关系
8.2.2、使用association处理映射关系
8.2.3、分步查询
①查询员工信息
②根据员工所对应的部门id查询部门信息
8.3、一对多映射处理
8.3.1、collection
8.3.2、分步查询

①查询部门信息
②根据部门id查询部门中的所有员工
9、动态SQL
9.1、if
9.2、where
9.3、trim
9.4、choose、when、otherwise
9.5、foreach
9.6、SQL片段
10、MyBatis的缓存
10.1、MyBatis的一级缓存
10.2、MyBatis的二级缓存
10.3、二级缓存的相关配置
10.4、MyBatis缓存查询的顺序
10.5、整合第三方缓存EHCache
10.5.1、添加依赖
10.5.2、各jar包功能
10.5.3、创建EHCache的配置文件ehcache.xml
10.5.4、设置二级缓存的类型
10.5.5、加入logback日志
10.5.6、EHCache配置文件说明11、MyBatis的逆向工程
11.1、创建逆向工程的步骤
①添加依赖和插件
②创建MyBatis的核心配置文件
③创建逆向工程的配置文件
④执行MBG插件的generate目标
⑤效果
11.2、QBC查询
12、分页插件
12.1、分页插件的使用步骤
①添加依赖
②配置分页插件
12.2、分页插件的使用
二、Spring
1、Spring简介
1.1、Spring概述
1.2、Spring家族
1.3、Spring Framework
1.3.1、Spring Framework特性
1.3.2、Spring Framework五大功能模块
2、IOC
2.1、IOC容器
2.1.1、IOC思想
①获取资源的传统方式
②反转控制方式获取资源
③DI
2.1.2、IOC容器在Spring中的实现
①BeanFactory
②ApplicationContext
③ApplicationContext的主要实现类
2.2、基于XML管理bean
2.2.1、实验一:入门案例
①创建Maven Module
②引入依赖
③创建类HelloWorld
④创建Spring的配置文件
⑤在Spring的配置文件中配置bean

⑥创建测试类测试
⑦思路
⑧注意
2.2.2、实验二:获取bean
①方式一:根据id获取
②方式二:根据类型获取
③方式三:根据id和类型
④注意
⑤扩展
⑥结论
2.2.3、实验三:依赖注入之setter注入
①创建学生类Student
②配置bean时为属性赋值
③测试
2.2.4、实验四:依赖注入之构造器注入
①在Student类中添加有参构造
②配置bean
③测试
2.2.5、实验五:特殊值处理
①字面量赋值
②null值
③xml实体
④CDATA节
2.2.6、实验六:为类类型属性赋值
①创建班级类Clazz
②修改Student类
③方式一:引用外部已声明的bean
④方式二:内部bean
③方式三:级联属性赋值
2.2.7、实验七:为数组类型属性赋值
①修改Student类
②配置bean
2.2.8、实验八:为集合类型属性赋值
①为List集合类型属性赋值
②为Map集合类型属性赋值
③引用集合类型的bean
2.2.9、实验九:p命名空间
2.2.10、实验十:引入外部属性文件
①加入依赖
②创建外部属性文件
③引入属性文件
④配置bean
⑤测试
2.2.11、实验十一:bean的作用域
①概念
②创建类User
③配置bean
④测试
2.2.12、实验十二:bean的生命周期
①具体的生命周期过程
②修改类User
③配置bean
④测试
⑤bean的后置处理器
2.2.13、实验十三:FactoryBean
①简介
②创建类UserFactoryBean
③配置bean

④测试
2.2.14、实验十四:基于xml的自动装配
①场景模拟
②配置bean
③测试
2.3、基于注解管理bean
2.3.1、实验一:标记与扫描
①注解
②扫描
③新建Maven Module
④创建Spring配置文件
⑤标识组件的常用注解
⑥创建组件
⑦扫描组件
⑧测试
⑨组件所对应的bean的id
2.3.2、实验二:基于注解的自动装配
①场景模拟
②@Autowired注解
③@Autowired注解其他细节
④@Autowired工作流程
3、AOP
3.1、场景模拟
3.1.1、声明接口
3.1.2、创建实现类
3.1.3、创建带日志功能的实现类
3.1.4、提出问题
①现有代码缺陷
②解决思路
③困难
3.2、代理模式
3.2.1、概念
①介绍
②生活中的代理
③相关术语
3.2.2、静态代理
3.2.3、动态代理
3.2.4、测试
3.3、AOP概念及相关术语
3.3.1、概述
3.3.2、相关术语
①横切关注点
②通知
③切面
④目标
⑤代理
⑥连接点
⑦切入点
3.3.3、作用
3.4、基于注解的AOP
3.4.1、技术说明
3.4.2、准备工作
①添加依赖
②准备被代理的目标资源
3.4.3、创建切面类并配置
3.4.4、各种通知
3.4.5、切入点表达式语法
①作用

②语法细节
3.4.6、重用切入点表达式
①声明
②在同一个切面中使用
③在不同切面中使用
3.4.7、获取通知的相关信息
①获取连接点信息
②获取目标方法的返回值
③获取目标方法的异常
3.4.8、环绕通知
3.4.9、切面的优先级
3.5、基于XML的AOP(了解)
3.5.1、准备工作
3.5.2、实现
4、声明式事务
4.1、JdbcTemplate
4.1.1、简介
4.1.2、准备工作
①加入依赖
②创建jdbc.properties
③配置Spring的配置文件
4.1.3、测试
①在测试类装配 JdbcTemplate
②测试增删改功能
③查询一条数据为实体类对象
④查询多条数据为一个list集合
⑤查询单行单列的值
4.2、声明式事务概念
4.2.1、编程式事务
4.2.2、声明式事务
4.3、基于注解的声明式事务
4.3.1、准备工作
①加入依赖
②创建jdbc.properties
③配置Spring的配置文件
④创建表
⑤创建组件
4.3.2、测试无事务情况
①创建测试类
②模拟场景
③观察结果
4.3.3、加入事务
①添加事务配置
②添加事务注解
③观察结果
4.3.4、@Transactional注解标识的位置
4.3.5、事务属性:只读
①介绍
②使用方式
③注意
4.3.6、事务属性:超时
①介绍
②使用方式
③观察结果
4.3.7、事务属性:回滚策略
①介绍
②使用方式
③观察结果

4.3.8、事务属性:事务隔离级别
①介绍
②使用方式
4.3.9、事务属性:事务传播行为
①介绍
②测试
③观察结果
4.4、基于XML的声明式事务
4.3.1、场景模拟
4.3.2、修改Spring配置文件
三、SpringMVC
1、SpringMVC简介
1.1、什么是MVC
1.2、什么是SpringMVC
1.3、SpringMVC的特点
2、入门案例
2.1、开发环境
2.2、创建maven工程
①添加web模块
②打包方式:war
③引入依赖
2.3、配置web.xml
①默认配置方式
②扩展配置方式
2.4、创建请求控制器
2.5、创建SpringMVC的配置文件
2.6、测试HelloWorld
①实现对首页的访问
②通过超链接跳转到指定页面
2.7、总结
3、@RequestMapping注解
3.1、@RequestMapping注解的功能
3.2、@RequestMapping注解的位置
3.3、@RequestMapping注解的value属性
3.4、@RequestMapping注解的method属性
3.5、@RequestMapping注解的params属性(了解)
3.6、@RequestMapping注解的headers属性(了解)
3.7、SpringMVC支持ant风格的路径
3.8、SpringMVC支持路径中的占位符(重点)
4、SpringMVC获取请求参数
4.1、通过ServletAPI获取
4.2、通过控制器方法的形参获取请求参数
4.3、@RequestParam
4.4、 @RequestHeader 4.5、@CookieValue
4.6、通过POJO获取请求参数
4.7、解决获取请求参数的乱码问题
5、域对象共享数据
5.1、使用ServletAPI向request域对象共享数据
5.2、使用ModelAndView向request域对象共享数据5.3、使用Model向request域对象共享数据
5.4、使用map向request域对象共享数据
5.5、使用ModelMap向request域对象共享数据
5.6、Model、ModelMap、Map的关系
5.7、向session域共享数据
5.8、向application域共享数据
6、SpringMVC的视图
6.1、ThymeleafView

6.2、转发视图
6.3、重定向视图
6.4、视图控制器view-controller
7、RESTful
7.1、RESTful简介
①资源
②资源的表述
③状态转移
7.2、RESTful的实现
7.3、HiddenHttpMethodFilter
8、RESTful案例
8.1、准备工作
8.2、功能清单
8.3、具体功能:访问首页
①配置view-controller
②创建页面
8.4、具体功能:查询所有员工数据
①控制器方法
②创建employee_list.html
8.5、具体功能:删除
①创建处理delete请求方式的表单
②删除超链接绑定点击事件
③控制器方法
8.6、具体功能:跳转到添加数据页面
①配置view-controller
②创建employee_add.html
8.7、具体功能:执行保存
①控制器方法
8.8、具体功能:跳转到更新数据页面
①修改超链接
②控制器方法
③创建employee_update.html
8.9、具体功能:执行更新
①控制器方法
9、SpringMVC处理ajax请求
9.1、@RequestBody
9.2、@RequestBody获取json格式的请求参数
9.3、@ResponseBody
9.4、@ResponseBody响应浏览器json数据
9.5、@RestController注解
10、文件上传和下载
10.1、文件下载
10.2、文件上传
11、拦截器
11.1、拦截器的配置
11.2、拦截器的三个抽象方法
11.3、多个拦截器的执行顺序
12、异常处理器
12.1、基于配置的异常处理
12.2、基于注解的异常处理
13、注解配置SpringMVC
13.1、创建初始化类,代替web.xml
13.2、创建SpringConfig配置类,代替spring的配置文件
13.3、创建WebConfig配置类,代替SpringMVC的配置文件
13.4、测试功能
14、SpringMVC执行流程
14.1、SpringMVC常用组件
14.2、DispatcherServlet初始化过程

①初始化WebApplicationContext
②创建WebApplicationContext
③DispatcherServlet初始化策略
14.3、DispatcherServlet调用组件处理请求
①processRequest()
②doService()
③doDispatch()
④processDispatchResult()
14.4、SpringMVC的执行流程
四、SSM整合
4.1、ContextLoaderListener
4.2、准备工作
①创建Maven Module
②导入依赖
③创建表
4.3、配置web.xml
4.4、创建SpringMVC的配置文件并配置
4.5、搭建MyBatis环境
①创建属性文件jdbc.properties
②创建MyBatis的核心配置文件mybatis-config.xml
③创建Mapper接口和映射文件
④创建日志文件log4j.xml
4.6、创建Spring的配置文件并配置
4.7、测试功能
①创建组件
②创建页面
③访问测试分页功能

一、MyBatis

1、MyBatis简介

1.1、MyBatis历史
MyBatis最初是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation迁移到了Google Code。随着开发团队转投Google Code旗下, iBatis3.x正式更名为MyBatis。代码于
2013年11月迁移到Github。
iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。 iBatis提供的持久层框架包括SQL Maps和Data Access Objects(DAO)。
1.2、MyBatis特性
1)MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架
2)MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集
3)MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java
Objects,普通的Java对象)映射成数据库中的记录
4)MyBatis 是一个 半自动的ORM(Object Relation Mapping)框架
1.3、MyBatis下载
MyBatis下载地址:https://github.com/mybatis/mybatis-3

Mabtis知识点总结_第1张图片
Mabtis知识点总结_第2张图片
1.4、和其它持久化层技术对比
JDBC
SQL 夹杂在Java代码中耦合度高,导致硬编码内伤
维护不易且实际开发需求中 SQL 有变化,频繁修改的情况多见代码冗长,开发效率低
Hibernate 和 JPA
操作简便,开发效率高
程序中的长难复杂 SQL 需要绕过框架
内部自动生产的 SQL,不容易做特殊优化
基于全映射的全自动框架,大量字段的 POJO 进行部分映射时比较困难。反射操作太多,导致数据库性能下降
MyBatis
轻量级,性能出色
SQL 和 Java 编码分开,功能边界清晰。Java代码专注业务、SQL语句专注数据开发效率稍逊于HIbernate,但是完全能够接受

2、搭建MyBatis
2.1、开发环境
IDE:idea 2019.2
构建工具:maven 3.5.4
MySQL版本:MySQL 8
MyBatis版本:MyBatis 3.5.7
MySQL不同版本的注意事项
1、驱动类driver-class-name
MySQL 5版本使用jdbc5驱动,驱动类使用:com.mysql.jdbc.Driver MySQL 8版本使用jdbc8驱动,驱动类使用:com.mysql.cj.jdbc.Driver
2 、 连 接 地 址 url MySQL 5版本的url:
jdbc:mysql://localhost:3306/ssm
MySQL 8 版 本 的 url: jdbc:mysql://localhost:3306/ssm?serverTimezone=UTC 否则运行测试用例报告如下错误:
java.sql.SQLException: The server time zone value ‘Öйú±ê׼ʱ¼ä’ is unrecognized or represents more

2.2、创建maven工程
①打包方式:jar
②引入依赖

<dependencies>
<!-- Mybatis核心 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>

<!-- junit测试 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>

<!-- MySQL驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.16</version>
</dependency>
</dependencies>

2.3、创建MyBatis的核心配置文件
习惯上命名为mybatis-config.xml,这个文件名仅仅只是建议,并非强制要求。将来整合Spring 之后,这个配置文件可以省略,所以大家操作时可以直接复制、粘贴。
核心配置文件主要用于配置连接数据库的环境以及MyBatis的全局配置信息核心配置文件存放的位置是src/main/resources目录下


<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

<!--设置连接数据库的环境-->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/ssm? serverTimezone=UTC"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>
<!--引入映射文件-->
<mappers>
<mapper resource="mappers/UserMapper.xml"/>
</mappers>
</configuration>
在这里插入代码片

2.4、创建mapper接口

MyBatis中的mapper接口相当于以前的dao。但是区别在于,mapper仅仅是接口,我们不需要 提供实现类。

public interface UserMapper {

/**
* 添加用户信息
*/
int insertUser();

}

2.5、创建MyBatis的映射文件
相关概念:ORM(Object Relationship Mapping)对象关系映射。对象:Java的实体类对象
关系:关系型数据库
映射:二者之间的对应关系

Java概念 | 数据库概念
类 | 表
属性 | 字段/列
对象 | 记录/行

1、映射文件的命名规则:
表所对应的实体类的类名+Mapper.xml
例如:表t_user,映射的实体类为User,所对应的映射文件为UserMapper.xml 因此一个映射文件对应一个实体类,对应一张表的操作
MyBatis映射文件用于编写SQL,访问以及操作表中的数据
MyBatis映射文件存放的位置是src/main/resources/mappers目录下
2、 MyBatis中可以面向接口操作数据,要保证两个一致:
a>mapper接口的全类名和映射文件的命名空间(namespace)保持一致
b>mapper接口中方法的方法名和映射文件中编写SQL的标签的id属性保持一致

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.softeem.mybatis.mapper.UserMapper">

<!--int insertUser();-->
<insert id="insertUser">
insert into t_user values(null,'admin','123456',23,'男','12345@qq.com')
</insert>

</mapper>

2.6、通过junit测试功能

//读取MyBatis的核心配置文件
InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
//创建SqlSessionFactoryBuilder对象SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
//通过核心配置文件所对应的字节输入流创建工厂类SqlSessionFactory,生产SqlSession对象
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
//创建SqlSession对象,此时通过SqlSession对象所操作的sql都必须手动提交或回滚事务
//SqlSession sqlSession = sqlSessionFactory.openSession();
//创建SqlSession对象,此时通过SqlSession对象所操作的sql都会自动提交SqlSession sqlSession = sqlSessionFactory.openSession(true);
//通过代理模式创建UserMapper接口的代理实现类对象
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
//调用UserMapper接口中的方法,就可以根据UserMapper的全类名匹配元素文件,通过调用的方法名匹配  映射文件中的SQL标签,并执行标签中的SQL语句
int result = userMapper.insertUser();
//sqlSession.commit();
System.out.println("结果:"+result);

SqlSession:代表Java程序和数据库之间的会话。(HttpSession是Java程序和浏览器之间的 会话)
SqlSessionFactory:是“生产”SqlSession的“工厂”。
工厂模式:如果创建某一个对象,使用的过程基本固定,那么我们就可以把创建这个对象的 相关代码封装到一个“工厂类”中,以后都使用这个工厂类来“生产”我们需要的对象。

2.7、加入log4j日志功能
①加入依赖

<!-- log4j日志 -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>

②加入log4j的配置文件
log4j的配置文件名为log4j.xml,存放的位置是src/main/resources目录下

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

<appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
<param name="Encoding" value="UTF-8" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS}
%m	(%F:%L) \n" />
</layout>
</appender>
<logger name="java.sql">
<level value="debug" />
</logger>
<logger name="org.apache.ibatis">
<level value="info" />
</logger>
<root>
<level value="debug" />
<appender-ref ref="STDOUT" />
</root>
</log4j:configuration>

日志的级别
FATAL(致命)>ERROR(错误)>WARN(警告)>INFO(信息)>DEBUG(调试)
从左到右打印的内容越来越详细

3、核心配置文件详解

核心配置文件中的标签必须按照固定的顺序:
properties?,settings?,typeAliases?,typeHandlers?,objectFactory?,objectWrapperFactory?,refl ectorFactory?,plugins?,environments?,databaseIdProvider?,mappers?

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

<!--
MyBatis 核 心 配 置 文 件 中 , 标 签 的 顺 序 : properties?,settings?,typeAliases?,typeHandlers?, objectFactory?,objectWrapperFactory?,reflectorFactory?, plugins?,environments?,databaseIdProvider?,mappers?
-->

<!--引入properties文件-->
<properties resource="jdbc.properties" />

<!--设置类型别名-->
<typeAliases>
<!--
typeAlias:设置某个类型的别名属性:
type:设置需要设置别名的类型
alias:设置某个类型的别名,若不设置该属性,那么该类型拥有默认的别名,即类名
且不区分大小写
-->
<!--<typeAlias type="com.softeem.mybatis.pojo.User"></typeAlias>-->
<!--以包为单位,将包下所有的类型设置默认的类型别名,即类名且不区分大小写-->
<package name="com.softeem.mybatis.pojo"/>
</typeAliases>

<!--
environments:配置多个连接数据库的环境属性:
default:设置默认使用的环境的id
-->
<environments default="development">
<!--





-->


environment:配置某个具体的环境属性:
id:表示连接数据库的环境的唯一标识,不能重复

<environment id="development">
<!--
transactionManager:设置事务管理方式属性:
type="JDBC|MANAGED"
JDBC:表示当前环境中,执行SQL时,使用的是JDBC中原生的事务管理方式,事 务的提交或回滚需要手动处理
MANAGED:被管理,例如Spring
-->
<transactionManager type="JDBC"/>
<!--
dataSource:配置数据源属性:
type:设置数据源的类型type="POOLED|UNPOOLED|JNDI"
POOLED:表示使用数据库连接池缓存数据库连接
UNPOOLED:表示不使用数据库连接池
JNDI:表示使用上下文中的数据源
-->
<dataSource type="POOLED">
<!--设置连接数据库的驱动-->
<property name="driver" value="${jdbc.driver}"/>
<!--设置连接数据库的连接地址-->
<property name="url" value="${jdbc.url}"/>
<!--设置连接数据库的用户名-->
<property name="username" value="${jdbc.username}"/>
<!--设置连接数据库的密码-->
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>


<environment id="test">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/ssm?serverTimezone=UTC"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>
<!--引入映射文件-->
<mappers>
<!--<mapper resource="mappers/UserMapper.xml"/>-->
<!--
以包为单位引入映射文件要求:
1、mapper接口所在的包要和映射文件所在的包一致
2、mapper接口要和映射文件的名字一致
-->
<package name="com.softeem.mybatis.mapper"/>
</mappers>
</configuration>

4、MyBatis的增删改查
4.1、新增

<!--int insertUser();-->
<insert id="insertUser">
insert into t_user values(null,'admin','123456',23,'男')
</insert>

4.2、删除

<!--int deleteUser();-->
<delete id="deleteUser">
delete from t_user where id = 7
</delete>

4.3、修改

<!--int updateUser();-->
<update id="updateUser">
update t_user set username='ybc',password='123' where id = 6
</update>

4.4、查询一个实体类对象

<!--User getUserById();-->
<select id="getUserById" resultType="com.softeem.mybatis.bean.User"> select * from t_user where id = 2
</select>

4.5、查询list集合

<!--List<User> getUserList();-->
<select id="getUserList" resultType="com.softeem.mybatis.bean.User"> select * from t_user
</select>

注意:
1、查询的标签select必须设置属性resultType或resultMap,用于设置实体类和数据库表的映射 关系
resultType:自动映射,用于属性名和表中字段名一致的情况
resultMap:自定义映射,用于一对多或多对一或字段名和属性名不一致的情况

5、MyBatis获取参数值的两种方式
MyBatis获取参数值的两种方式:${}和#{}
${}的本质就是字符串拼接,#{}的本质就是占位符赋值
KaTeX parse error: Expected 'EOF', got '#' at position 52: …值时,需要手动加单引 号;但是#̲{}使用占位符赋值的方式拼接s…{}和#{}以任意的名称获取参数的值,注意 需要手动加单引号 5.2 、多个字面量类型的参数若 m a p p e r 接口中的方法参数为多个时此时 M y B a t i s 会自动将这些参数放在一个 m a p 集合中,以 a r g 0 , a r g 1... 为键,以参数为值;以 p a r a m 1 , p a r a m 2... 为键,以参数为值;因此只需要通过 {}需要手动加单引号 5.2、多个字面量类型的参数 若mapper接口中的方法参数为多个时 此时MyBatis会自动将这些参数放在一个map集合中,以arg0,arg1...为键,以参数为值;以 param1,param2...为键,以参数为值;因此只需要通过 需要手动加单引号5.2、多个字面量类型的参数若mapper接口中的方法参数为多个时此时MyBatis会自动将这些参数放在一个map集合中,以arg0,arg1...为键,以参数为值;以param1,param2...为键,以参数为值;因此只需要通过{}和#{}访问map集合的键就可以获取相 对应的
值,注意 需要手动加单引号 5.3 、 m a p 集合类型的参数若 m a p p e r 接口中的方法需要的参数为多个时,此时可以手动创建 m a p 集合,将这些数据放在 m a p 中只需要通过 {}需要手动加单引号 5.3、map集合类型的参数 若mapper接口中的方法需要的参数为多个时,此时可以手动创建map集合,将这些数据放在 map中 只需要通过 需要手动加单引号5.3map集合类型的参数若mapper接口中的方法需要的参数为多个时,此时可以手动创建map集合,将这些数据放在map中只需要通过{}和#{}访问map集合的键就可以获取相对应的值,注意 需要手动加单引号 5.4 、实体类类型的参数若 m a p p e r 接口中的方法参数为实体类对象时此时可以使用 {}需要手动加单引号 5.4、实体类类型的参数 若mapper接口中的方法参数为实体类对象时 此时可以使用 需要手动加单引号5.4、实体类类型的参数若mapper接口中的方法参数为实体类对象时此时可以使用{}和#{},通过访问实体类对象中的属性名获取属性值,注意 需要手动加单引号 5.5 、使用 @ P a r a m 标识参数可以通过 @ P a r a m 注解标识 m a p p e r 接口中的方法参数此时,会将这些参数放在 m a p 集合中,以 @ P a r a m 注解的 v a l u e 属性值为键,以参数为值;以 p a r a m 1 , p a r a m 2... 为键,以参数为值;只需要通过 {}需要手动加单引号 5.5、使用@Param标识参数 可以通过@Param注解标识mapper接口中的方法参数 此时,会将这些参数放在map集合中,以@Param注解的value属性值为键,以参数为值;以 param1,param2...为键,以参数为值;只需要通过 需要手动加单引号5.5、使用@Param标识参数可以通过@Param注解标识mapper接口中的方法参数此时,会将这些参数放在map集合中,以@Param注解的value属性值为键,以参数为值;以param1,param2...为键,以参数为值;只需要通过{}和#{}访问map集合的键就可以获取相对应 的值,
注意${}需要手动加单引号
6、MyBatis的各种查询功能
6.1、查询一个实体类对象

/**
*根据用户id查询用户信息
*@param id
*@return
*/
User getUserById(@Param("id") int id);
<!--User getUserById(@Param("id") int id);-->
<select id="getUserById" resultType="User"> select * from t_user where id = #{id}
</select>

6.2、查询一个list集合

/**
*查询所有用户信息
*@return
*/
List<User> getUserList();
<!--List<User> getUserList();-->
<select id="getUserList" resultType="User"> select * from t_user
</select>

当查询的数据为多条时,不能使用实体类作为返回值,否则会抛出异常
TooManyResultsException;但是若查询的数据只有一条,可以使用实体类或集合作为返回值

6.3、查询单个数据

/**
*查询用户的总记录数
*@return
*在MyBatis中,对于Java中常用的类型都设置了类型别名
*例如: java.lang.Integer-->int|integer
*例如: int-->_int|_integer
*例如: Map-->map,List-->list
*/
int getCount();
<!--int getCount();-->
<select id="getCount" resultType="_integer"> select count(id) from t_user
</select>

6.4、查询一条数据为map集合

/**
*根据用户id查询用户信息为map集合
*@param id
*@return
*/
Map<String, Object> getUserToMap(@Param("id") int id);
<!--Map<String, Object> getUserToMap(@Param("id") int id);-->
<!--结果: {password=123456, sex=, id=1, age=23, username=admin}-->
<select id="getUserToMap" resultType="map"> select * from t_user where id = #{id}
</select>

6.5、查询多条数据为map集合
①方式一

/**
*查询所有用户信息为map集合

*@return
*将表中的数据以map集合的方式查询,一条数据对应一个map;若有多条数据,就会产生多个map集合,此  时可以将这些map放在一个list集合中获取
*/
List<Map<String, Object>> getAllUserToMap();

<!--Map<String, Object> getAllUserToMap();-->
<select id="getAllUserToMap" resultType="map"> select * from t_user
</select>

②方式二

/**
*查询所有用户信息为map集合

*@return
*将表中的数据以map集合的方式查询,一条数据对应一个map;若有多条数据,就会产生多个map集合,并  且最终要以一个map的方式返回数据,此时需要通过@MapKey注解设置map集合的键,值是每条数据所对应的
map集合
*/ @MapKey("id")
Map<String, Object> getAllUserToMap();
<!--Map<String, Object> getAllUserToMap();-->
<!--
{
1={password=123456, sex=, id=1, age=23, username=admin}, 2={password=123456, sex=, id=2, age=23, username=张三}, 3={password=123456, sex=, id=3, age=23, username=张三}
}
-->
<select id="getAllUserToMap" resultType="map"> select * from t_user
</select>

7、特殊SQL的执行

7.1、模糊查询

/**
*测试模糊查询
*@param mohu
*@return
*/
List<User> testMohu(@Param("mohu") String mohu);
<!--List<User> testMohu(@Param("mohu") String mohu);-->
<select id="testMohu" resultType="User">
<!--select * from t_user where username like '%${mohu}%'-->
<!--select * from t_user where username like concat('%',#{mohu},'%')--> select * from t_user where username like "%"#{mohu}"%"
</select>

7.2、批量删除

/**
*批量删除
*@param ids
*@return
*/
int deleteMore(@Param("ids") String ids);
<!--int deleteMore(@Param("ids") String ids);-->
<delete id="deleteMore">
delete from t_user where id in (${ids})
</delete>

7.3、动态设置表名

/**
*动态设置表名,查询所有的用户信息
*@param tableName
*@return
*/
List<User> getAllUser(@Param("tableName") String tableName);
<!--List<User> getAllUser(@Param("tableName") String tableName);-->
<select id="getAllUser" resultType="User"> select * from ${tableName}
</select>

7.4、添加功能获取自增的主键
场景模拟:
t_clazz(clazz_id,clazz_name) t_student(student_id,student_name,clazz_id)
1、添加班级信息
2、获取新添加的班级的id
3、为班级分配学生,即将某学的班级id修改为新添加的班级的id

/**
*添加用户信息
*@param user
*@return
*useGeneratedKeys:设置使用自增的主键
*keyProperty:因为增删改有统一的返回值是受影响的行数,因此只能将获取的自增的主键放在传输的参  数user对象的某个属性中
*/
int insertUser(User user);
<!--int insertUser(User user);-->
<insert id="insertUser" useGeneratedKeys="true" keyProperty="id">
insert into t_user values(null,#{username},#{password},#{age},#{sex})
</insert>

8、自定义映射resultMap
8.1、resultMap处理字段和属性的映射关系
若字段名和实体类中的属性名不一致,则可以通过resultMap设置自定义映射

<!--
resultMap:设置自定义映射属性:
id:表示自定义映射的唯一标识
type:查询的数据要映射的实体类的类型子标签:
id:设置主键的映射关系
result:设置普通字段的映射关系
association:设置多对一的映射关系
collection:设置一对多的映射关系属性:
property:设置映射关系中实体类中的属性名
column:设置映射关系中表中的字段名
-->
<resultMap id="userMap" type="User">
<id property="id" column="id"></id>
<result property="userName" column="user_name"></result>
<result property="password" column="password"></result>
<result property="age" column="age"></result>
<result property="sex" column="sex"></result>
</resultMap>
<!--List<User> testMohu(@Param("mohu") String mohu);-->
<select id="testMohu" resultMap="userMap">
<!--select * from t_user where username like '%${mohu}%'-->
select id,user_name,password,age,sex from t_user where user_name like concat('%',#{mohu},'%')
</select>

若字段名和实体类中的属性名不一致,但是字段名符合数据库的规则(使用_),实体类中的属性 名符合Java的规则(使用驼峰)
此时也可通过以下两种方式处理字段名和实体类中的属性的映射关系
a>可以通过为字段起别名的方式,保证和实体类中的属性名保持一致
b>可以在MyBatis的核心配置文件中设置一个全局配置信息mapUnderscoreToCamelCase,可以在查询表中数据时,自动将_类型的字段名转换为驼峰
例如:字段名user_name,设置了mapUnderscoreToCamelCase,此时字段名就会转换为
userName
8.2、多对一映射处理
场景模拟:
查询员工信息以及员工所对应的部门信息
8.2.1、级联方式处理映射关系

<resultMap id="empDeptMap" type="Emp">
<id column="eid" property="eid"></id>
<result column="ename" property="ename"></result>
<result column="age" property="age"></result>
<result column="sex" property="sex"></result>
<result column="did" property="dept.did"></result>
<result column="dname" property="dept.dname"></result>
</resultMap>
<!--Emp getEmpAndDeptByEid(@Param("eid") int eid);-->
<select id="getEmpAndDeptByEid" resultMap="empDeptMap">
select emp.*,dept.* from t_emp emp left join t_dept dept on emp.did = dept.did where emp.eid = #{eid}
</select>

8.2.2、使用association处理映射关系

<resultMap id="empDeptMap" type="Emp">
<id column="eid" property="eid"></id>
<result column="ename" property="ename"></result>
<result column="age" property="age"></result>
<result column="sex" property="sex"></result>
<association property="dept" javaType="Dept">
<id column="did" property="did"></id>
<result column="dname" property="dname"></result>
</association>
</resultMap>
<!--Emp getEmpAndDeptByEid(@Param("eid") int eid);-->
<select id="getEmpAndDeptByEid" resultMap="empDeptMap">
select emp.*,dept.* from t_emp emp left join t_dept dept on emp.did = dept.did where emp.eid = #{eid}
</select>

8.2.3、分步查询
①查询员工信息

/**
*通过分步查询查询员工信息
*@param eid
*@return
*/
Emp getEmpByStep(@Param("eid") int eid);
<resultMap id="empDeptStepMap" type="Emp">
<id column="eid" property="eid"></id>
<result column="ename" property="ename"></result>
<result column="age" property="age"></result>
<result column="sex" property="sex"></result>
<!--
select:设置分步查询,查询某个属性的值的sql的标识(namespace.sqlId)
column:将sql以及查询结果中的某个字段设置为分步查询的条件
-->
<association property="dept" select="com.softeem.MyBatis.mapper.DeptMapper.getEmpDeptByStep" column="did">
</association>
</resultMap>
<!--Emp getEmpByStep(@Param("eid") int eid);-->
<select id="getEmpByStep" resultMap="empDeptStepMap"> select * from t_emp where eid = #{eid}
</select>

②根据员工所对应的部门id查询部门信息

/**
*分步查询的第二步: 根据员工所对应的did查询部门信息
*@param did
*@return
*/
Dept getEmpDeptByStep(@Param("did") int did);
<!--Dept getEmpDeptByStep(@Param("did") int did);-->
<select id="getEmpDeptByStep" resultType="Dept"> select * from t_dept where did = #{did}
</select>

8.3、一对多映射处理
8.3.1、collection

/**
*根据部门id查新部门以及部门中的员工信息
*@param did
*@return
*/
Dept getDeptEmpByDid(@Param("did") int did);
<resultMap id="deptEmpMap" type="Dept">
<id property="did" column="did"></id>
<result property="dname" column="dname"></result>
<!--
ofType:设置collection标签所处理的集合属性中存储数据的类型
-->
<collection property="emps" ofType="Emp">
<id property="eid" column="eid"></id>
<result property="ename" column="ename"></result>
<result property="age" column="age"></result>
<result property="sex" column="sex"></result>
</collection>
</resultMap>
<!--Dept getDeptEmpByDid(@Param("did") int did);-->
<select id="getDeptEmpByDid" resultMap="deptEmpMap">
select dept.*,emp.* from t_dept dept left join t_emp emp on dept.did = emp.did where dept.did = #{did}
</select>

8.3.2、分步查询
①查询部门信息

/**
*分步查询部门和部门中的员工
*@param did
*@return
*/
Dept getDeptByStep(@Param("did") int did);
<resultMap id="deptEmpStep" type="Dept">
<id property="did" column="did"></id>
<result property="dname" column="dname"></result>
<collection property="emps" fetchType="eager" select="com.softeem.MyBatis.mapper.EmpMapper.getEmpListByDid" column="did">
</collection>
</resultMap>
<!--Dept getDeptByStep(@Param("did") int did);-->
<select id="getDeptByStep" resultMap="deptEmpStep"> select * from t_dept where did = #{did}
</select>

②根据部门id查询部门中的所有员工

/**
*根据部门id查询员工信息
*@param did
*@return
*/
List<Emp> getEmpListByDid(@Param("did") int did);
<!--List<Emp> getEmpListByDid(@Param("did") int did);-->
<select id="getEmpListByDid" resultType="Emp"> select * from t_emp where did = #{did}
</select>

分步查询的优点:可以实现延迟加载
但是必须在核心配置文件中设置全局配置信息:
lazyLoadingEnabled:延迟加载的全局开关。当开启时,所有关联对象都会延迟加载
aggressiveLazyLoading:当开启时,任何方法的调用都会加载该对象的所有属性。否则,每个属 性会按需加载
此时就可以实现按需加载,获取的数据是什么,就只会执行相应的sql。此时可通过association和
collection中的fetchType属性设置当前的分步查询是否使用延迟加载, fetchType=“lazy(延迟加载)|eager(立即加载)”

9、动态SQL
Mybatis框架的动态SQL技术是一种根据特定条件动态拼装SQL语句的功能,它存在的意义是为了 解决 拼接SQL语句字符串时的痛点问题。
9.1、if
if标签可通过test属性的表达式进行判断,若表达式的结果为true,则标签中的内容会执行;反之标签中的内容不会执行

<!--List<Emp> getEmpListByCondition(Emp emp);-->
<select id="getEmpListByMoreTJ" resultType="Emp"> select * from t_emp where 1=1
<if test="ename != '' and ename != null"> and ename = #{ename}
</if>
<if test="age != '' and age != null"> and age = #{age}
</if>
<if test="sex != '' and sex != null"> and sex = #{sex}
</if>
</select>

9.2、where
where和if一般结合使用:
a>若where标签中的if条件都不满足,则where标签没有任何功能,即不会添加where关键字
b>若where标签中的if条件满足,则where标签会自动添加where关键字,并将条件最前方多余的
and去掉
注意:where标签不能去掉条件最后多余的and

<select id="getEmpListByMoreTJ2" resultType="Emp"> select * from t_emp
<where>
<if test="ename != '' and ename != null"> ename = #{ename}
</if>
<if test="age != '' and age != null"> and age = #{age}
</if>
<if test="sex != '' and sex != null"> and sex = #{sex}
</if>
</where>
</select>

9.3、trim
trim用于去掉或添加标签中的内容常用属性:
prefix:在trim标签中的内容的前面添加某些内容
prefixOverrides:在trim标签中的内容的前面去掉某些内容
suffix:在trim标签中的内容的后面添加某些内容
suffixOverrides:在trim标签中的内容的后面去掉某些内容

<select id="getEmpListByMoreTJ" resultType="Emp"> select * from t_emp
<trim prefix="where" suffixOverrides="and">
<if test="ename != '' and ename != null">
ename = #{ename} and
</if>
<if test="age != '' and age != null"> age = #{age} and
</if>
<if test="sex != '' and sex != null"> sex = #{sex}
</if>
</trim>
</select>

9.4、choose、when、otherwise
choose、when、 otherwise相当于if…else if…else

<!--List<Emp> getEmpListByChoose(Emp emp);-->
<select id="getEmpListByChoose" resultType="Emp">
select <include refid="empColumns"></include> from t_emp
<where>
<choose>
<when test="ename != '' and ename != null"> ename = #{ename}
</when>
<when test="age != '' and age != null"> age = #{age}
</when>
<when test="sex != '' and sex != null"> sex = #{sex}
</when>
<when test="email != '' and email != null"> email = #{email}
</when>
</choose>
</where>
</select>

9.5、foreach

<!--int insertMoreEmp(List<Emp> emps);-->
<insert id="insertMoreEmp"> insert into t_emp values
<foreach collection="emps" item="emp" separator=","> (null,#{emp.ename},#{emp.age},#{emp.sex},#{emp.email},null)
</foreach>
</insert>
<!--int deleteMoreByArray(int[] eids);-->
<delete id="deleteMoreByArray"> delete from t_emp where
<foreach collection="eids" item="eid" separator="or"> eid = #{eid}
</foreach>
</delete>
<!--int deleteMoreByArray(int[] eids);-->
<delete id="deleteMoreByArray"> delete from t_emp where eid in
<foreach collection="eids" item="eid" separator="," open="(" close=")">
#{eid}
</foreach>
</delete>

9.6、SQL片段
sql片段,可以记录一段公共sql片段,在使用的地方通过include标签进行引入

<sql id="empColumns"> eid,ename,age,sex,did
</sql>
select <include refid="empColumns"></include> from t_emp

10、MyBatis的缓存
10.1、MyBatis的一级缓存
一级缓存是SqlSession级别的,通过同一个SqlSession查询的数据会被缓存,下次查询相同的数据,就 会从缓存中直接获取,不会从数据库重新访问
使一级缓存失效的四种情况:
1)不同的SqlSession对应不同的一级缓存
2)同一个SqlSession但是查询条件不同
3)同一个SqlSession两次查询期间执行了任何一次增删改操作
4)同一个SqlSession两次查询期间手动清空了缓存
10.2、MyBatis的二级缓存
二级缓存是SqlSessionFactory级别,通过同一个SqlSessionFactory创建的SqlSession查询的结果会被 缓存;此后若再次执行相同的查询语句,结果就会从缓存中获取
二级缓存开启的条件:
a>在核心配置文件中,设置全局配置属性cacheEnabled=“true”,默认为true,不需要设置
b>在映射文件中设置标签
c>二级缓存必须在SqlSession关闭或提交之后有效
d>查询的数据所转换的实体类类型必须实现序列化的接口使二级缓存失效的情况:
两次查询之间执行了任意的增删改,会使一级和二级缓存同时失效

10.3、二级缓存的相关配置
在mapper配置文件中添加的cache标签可以设置一些属性:
①eviction属性:缓存回收策略,默认的是 LRU。
LRU(Least Recently Used) – 最近最少使用的:移除最长时间不被使用的对象。
FIFO(First in First out) – 先进先出:按对象进入缓存的顺序来移除它们。
SOFT – 软引用:移除基于垃圾回收器状态和软引用规则的对象。

WEAK – 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象。
②flushInterval属性:刷新间隔,单位毫秒
默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新
③size属性:引用数目,正整数
代表缓存最多可以存储多少个对象,太大容易导致内存溢出
④readOnly属性:只读, true/false
true:只读缓存;会给所有调用者返回缓存对象的相同实例。因此这些对象不能被修改。这提供了 很重要的性能优势。
false:读写缓存;会返回缓存对象的拷贝(通过序列化)。这会慢一些,但是安全,因此默认是false。

10.4、MyBatis缓存查询的顺序
先查询二级缓存,因为二级缓存中可能会有其他程序已经查出来的数据,可以拿来直接使用。 如果二级缓存没有命中,再查询一级缓存
如果一级缓存也没有命中,则查询数据库
SqlSession关闭之后,一级缓存中的数据会写入二级缓存

10.5、整合第三方缓存EHCache
10.5.1、添加依赖

<!-- Mybatis EHCache整合包 -->
<dependency>
<groupId>org.mybatis.caches</groupId>
<artifactId>mybatis-ehcache</artifactId>
<version>1.2.1</version>
</dependency>
<!-- slf4j日志门面的一个具体实现 -->
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.3</version>
</dependency>

10.5.2、各jar包功能
Mabtis知识点总结_第3张图片

10.5.3、创建EHCache的配置文件ehcache.xml

<?xml version="1.0" encoding="utf-8" ?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">
<!-- 磁盘保存路径 -->
<diskStore path="D:\softeem\ehcache"/>
<defaultCache
maxElementsInMemory="1000" maxElementsOnDisk="10000000" eternal="false" overflowToDisk="true" timeToIdleSeconds="120" timeToLiveSeconds="120"
diskExpiryThreadIntervalSeconds="120" memoryStoreEvictionPolicy="LRU">
</defaultCache>
</ehcache>

10.5.4、设置二级缓存的类型

<cache type="org.mybatis.caches.ehcache.EhcacheCache"/>

10.5.5、加入logback日志
存在SLF4J时,作为简易日志的log4j将失效,此时我们需要借助SLF4J的具体实现logback来打印日志。 创建logback的配置文件logback.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
<!-- 指定日志输出的位置 -->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<!-- 日志输出的格式 -->
<!-- 按照顺序分别是: 时间、日志级别、线程名称、打印日志的类、日志主体内容、换行
-->
<pattern>[%d{HH:mm:ss.SSS}] [%-5level] [%thread] [%logger] [%msg]%n</pattern>
</encoder>
</appender>

<!-- 设置全局日志级别。日志级别按顺序分别是: DEBUGINFOWARNERROR -->
<!-- 指定任何一个日志级别都只打印当前级别和后面级别的日志。 -->
<root level="DEBUG">
<!-- 指定打印日志的appender,这里通过“STDOUT”引用了前面配置的appender -->
<appender-ref ref="STDOUT" />
</root>

<!-- 根据特殊需求指定局部日志级别 -->
<logger name="com.softeem.crowd.mapper" level="DEBUG"/>
</configuration>

10.5.6、EHCache配置文件说明
Mabtis知识点总结_第4张图片
11、MyBatis的逆向工程

正向工程:先创建Java实体类,由框架负责根据实体类生成数据库表。 Hibernate是支持正向工程的。
逆向工程:先创建数据库表,由框架负责根据数据库表,反向生成如下资源:
Java实体类
Mapper接口
Mapper映射文件
11.1、创建逆向工程的步骤
①添加依赖和插件

<!-- 依赖MyBatis核心包 -->
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>
<!-- junit测试 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>

<!-- log4j日志 -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.16</version>
</dependency>
</dependencies>

<!-- 控制Maven在构建过程中相关配置 -->
<build>

<!-- 构建过程中用到的插件 -->
<plugins>

<!-- 具体插件,逆向工程的操作是以构建过程中插件形式出现的 -->
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.0</version>

<!-- 插件的依赖 -->
<dependencies>

<!-- 逆向工程的核心依赖 -->
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.2</version>
</dependency>

<!-- MySQL驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.16</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>

②创建MyBatis的核心配置文件
③创建逆向工程的配置文件
文件名必须是:generatorConfig.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<!--
targetRuntime: 执行生成的逆向工程的版本
MyBatis3Simple: 生成基本的CRUD(清新简洁版)
MyBatis3: 生成带条件的CRUD(奢华尊享版)
-->
<context id="DB2Tables" targetRuntime="MyBatis3">
<!-- 数据库的连接信息 -->
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/mybatis?

serverTimezone=UTC"


userId="root" password="123456">

</jdbcConnection>
<!-- javaBean的生成策略-->
<javaModelGenerator targetPackage="com.softeem.mybatis.pojo" targetProject=".\src\main\java">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!-- SQL映射文件的生成策略 -->
<sqlMapGenerator targetPackage="com.softeem.mybatis.mapper" targetProject=".\src\main\resources">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
<!-- Mapper接口的生成策略 -->
<javaClientGenerator type="XMLMAPPER" targetPackage="com.softeem.mybatis.mapper"	targetProject=".\src\main\java">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
<!-- 逆向分析的表 -->
<!-- tableName设置为*号,可以对应所有表,此时不写domainObjectName -->
<!-- domainObjectName属性指定生成出来的实体类的类名 -->
<table tableName="t_emp" domainObjectName="Emp"/>
<table tableName="t_dept" domainObjectName="Dept"/>
</context>
</generatorConfiguration>

④执行MBG插件的generate目标
Mabtis知识点总结_第5张图片
⑤效果
Mabtis知识点总结_第6张图片
11.2、QBC查询

@Test
public void testMBG(){ try {
InputStream is = Resources.getResourceAsStream("mybatis-config.xml"); SqlSessionFactory sqlSessionFactory = new
SqlSessionFactoryBuilder().build(is);
SqlSession sqlSession = sqlSessionFactory.openSession(true); EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
//查询所有数据
/*List list = mapper.selectByExample(null); list.forEach(emp -> System.out.println(emp));*/
//根据条件查询
/*EmpExample example = new EmpExample();
example.createCriteria().andEmpNameEqualTo("张三").andAgeGreaterThanOrEqualTo(20);
example.or().andDidIsNotNull();
List list = mapper.selectByExample(example); list.forEach(emp -> System.out.println(emp));*/ mapper.updateByPrimaryKeySelective(new
Emp(1,"admin",22,null,"[email protected]",3));
} catch (IOException e) { 
e.printStackTrace();
}
}

12、分页插件
limit index, pageSize pageSize:每页显示的条数pageNum:当前页的页码
index:当前页的起始索引,index=(pageNum-1)*pageSize
count:总记录数totalPage:总页数
totalPage = count / pageSize; if(count % pageSize != 0){
totalPage += 1;
}
pageSize=4,pageNum=1,index=0 limit 0,4
pageSize=4,pageNum=3,index=8 limit 8,4
pageSize=4,pageNum=6,index=20 limit 20,4

首页 上一页 2 3 4 5 6 下一页 末页

12.1、分页插件的使用步骤
①添加依赖

<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.2.0</version>
</dependency>

②配置分页插件
在MyBatis的核心配置文件中配置插件

<plugins>
<!--设置分页插件-->
<plugin interceptor="com.github.pagehelper.PageInterceptor"></plugin>
</plugins>

12.2、分页插件的使用
a>在查询功能之前使用PageHelper.startPage(int pageNum, int pageSize)开启分页功能pageNum:当前页的页码
pageSize:每页显示的条数
b>在查询获取list集合之后,使用PageInfo pageInfo = new PageInfo<>(List list, int
navigatePages)获取分页相关数据
list:分页之后的数据navigatePages:导航分页的页码数
c>分页相关数据PageInfo{
pageNum=8, pageSize=4, size=2, startRow=29, endRow=30, total=30, pages=8, list=Page{count=true, pageNum=8, pageSize=4, startRow=28, endRow=32, total=30, pages=8, reasonable=false, pageSizeZero=false},
prePage=7, nextPage=0, isFirstPage=false, isLastPage=true, hasPreviousPage=true, hasNextPage=false, navigatePages=5, navigateFirstPage4, navigateLastPage8, navigatepageNums=[4, 5, 6, 7, 8]
}
pageNum:当前页的页码pageSize:每页显示的条数size:当前页显示的真实条数total: 总 记 录 数 pages: 总 页 数 prePage:上一页的页码nextPage:下一页的页码
isFirstPage/isLastPage:是否为第一页/最后一页
hasPreviousPage/hasNextPage:是否存在上一页/下一页navigatePages:导航分页的页码数navigatepageNums:导航分页的页码,[1,2,3,4,5]

你可能感兴趣的:(mybatis,java)