> 文档中心 > 2022最新最全MyBatis(简单全面,一发入魂,内容超详细)

2022最新最全MyBatis(简单全面,一发入魂,内容超详细)


目录

一、MyBatis简介

1、MyBatis历史

2、MyBatis特性

3、MyBatis下载

4、和其它持久化层技术对比

JDBC

Hibernate 和 JPA

MyBatis

二、搭建MyBatis

1、开发环境

2、创建maven工程

a>打包方式:jar

b>引入依赖

3、创建MyBatis的核心配置文件

4、创建mapper接口

5、创建MyBatis的映射文件

6、通过junit测试功能

7、加入log4j日志功能

a>加入依赖

b>加入log4j的配置文件

三、核心配置文件详解

四、MyBatis的增删改查

五、MyBatis获取参数值的两种方式(重点)

1、单个字面量类型的参数

2、多个字面量类型的参数

3、map集合类型的参数

4、实体类类型的参数

5、使用@Param标识参数

 六、MyBatis的各种查询功能

1、查询一个实体类对象

2、查询一个list集合

3、查询单个数据

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

5、查询多条数据为map集合

七、特殊SQL的执行

1、模糊查询

2、批量删除

3、动态设置表名

4、添加功能获取自增的主键

八、自定义映射resultMap

1、resultMap处理字段和属性的映射关系

2、多对一映射处理

a>级联方式处理映射关系

 b>使用association处理映射关系

3、一对多映射处理

a>collection

b>分步查询

九、动态SQL

1、if

2、where

3、trim

4、choose、when、otherwise

5、foreach

6、SQL片段

十、MyBatis的缓存

1、MyBatis的一级缓存

2、MyBatis的二级缓存

3、二级缓存的相关配置

4、MyBatis缓存查询的顺序

5、整合第三方缓存EHCache

a>添加依赖

b>各jar包功能

c>创建EHCache的配置文件ehcache.xml

d>设置二级缓存的类型

e>加入logback日志

f>EHCache配置文件说明

十一、MyBatis的逆向工程

1、创建逆向工程的步骤

a>添加依赖和插件

b>创建MyBatis的核心配置文件

c>创建逆向工程的配置文件

d>执行MBG插件的generate目标

2、QBC查询

十二、分页插件

1、分页插件使用步骤

a>添加依赖

b>配置分页插件

2、分页插件的使用


一、MyBatis简介

1MyBatis历史

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)。

2MyBatis特性

1) MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架 2) MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集 3) MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录 4) MyBatis 是一个 半自动的ORM(Object Relation Mapping)框架

3MyBatis下载

MyBatis下载地址:https://github.com/mybatis/mybatis-3 watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5LiA5Liq54Ot54ix57yW56iL55qE5bCP55m955m9,size_14,color_FFFFFF,t_70,g_se,x_16 watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5LiA5Liq54Ot54ix57yW56iL55qE5bCP55m955m9,size_14,color_FFFFFF,t_70,g_se,x_16

4、和其它持久化层技术对比

JDBC

SQL 夹杂在Java代码中耦合度高,导致硬编码内伤 维护不易且实际开发需求中 SQL 有变化,频繁修改的情况多见 代码冗长,开发效率低

Hibernate 和 JPA

操作简便,开发效率高 程序中的长难复杂 SQL 需要绕过框架 内部自动生产的 SQL,不容易做特殊优化 基于全映射的全自动框架,大量字段的 POJO 进行部分映射时比较困难。 反射操作太多,导致数据库性能下降

MyBatis

轻量级,性能出色 SQL 和 Java 编码分开,功能边界清晰。Java代码专注业务、SQL语句专注数据 开发效率稍逊于HIbernate,但是完全能够接受

二、搭建MyBatis

1、开发环境

IDE:idea 2019.2 构建工具:maven 3.5.4 MySQL版本:MySQL 5.7 MyBatis版本:MyBatis 3.5.7

2、创建maven工程

a>打包方式:jar

b>引入依赖

   org.mybatis mybatis 3.5.7    junit junit 4.12 test    mysql mysql-connector-java 5.1.3  

3、创建MyBatis的核心配置文件

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

 

提示:

下面的  username 和 password 为mysql的账号密码   根据自身实际情况进行改写  

                   

4、创建mapper接口

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

先创建用户类 类中属性 与 数据库中的字段对应

User类里面的代码:

public class User {    private  Integer id;    private  String username;    private  String password;    private  Integer age;    private  String sex;    private  String email;    public User() {    }    public User(Integer id, String username, String password, Integer age, String sex, String email) { this.id = id; this.username = username; this.password = password; this.age = age; this.sex = sex; this.email = email;    }    public Integer getId() { return id;    }    public void setId(Integer id) { this.id = id;    }    public String getUsername() { return username;    }    public void setUsername(String username) { this.username = username;    }    public String getPassword() { return password;    }    public void setPassword(String password) { this.password = password;    }    public Integer getAge() { return age;    }    public void setAge(Integer age) { this.age = age;    }    public String getSex() { return sex;    }    public void setSex(String sex) { this.sex = sex;    }    public String getEmail() { return email;    }    public void setEmail(String email) { this.email = email;    }    @Override    public String toString() { return "User{" +  "id=" + id +  ", username='" + username + '\'' +  ", password='" + password + '\'' +  ", age=" + age +  ", sex='" + sex + '\'' +  ", email='" + email + '\'' +  '}';    }}

创建UserMapper接口

public interface UserMapper { /*** 添加用户信息 */ int insertUser(); }

5、创建MyBatis的映射文件

相关概念: ORMObject Relationship Mapping)对象关系映射。 对象:Java的实体类对象 关系:关系型数据库 映射:二者之间的对应关系 watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5LiA5Liq54Ot54ix57yW56iL55qE5bCP55m955m9,size_16,color_FFFFFF,t_70,g_se,x_16

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

     insert into t_user values(null,'张三','123',23,'女')  

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();

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

7、加入log4j日志功能

a>加入依赖

  log4j log4j 1.2.17 

b>加入log4j的配置文件

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

                                             

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

三、核心配置文件详解

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

                               <!----> <!-- -->                                                                                

四、MyBatis的增删改查

1、添加

insert into t_user values(null,'admin','123456',23,'男')

2、删除

delete from t_user where id = 7

3、修改

update t_user set username='ybc',password='123' where id = 6

4、查询一个实体类对象

select * from t_user where id = 2

5、查询集合

<!--List getUserList();-->select * from t_user

注意: 1 、查询的标签 select 必须设置属性 resultType resultMap ,用于设置实体类和数据库表的映射 关系 resultType :自动映射,用于属性名和表中字段名一致的情况 resultMap :自定义映射,用于一对多或多对一或字段名和属性名不一致的情况 2 、当查询的数据为多条时,不能使用实体类作为返回值,只能使用集合,否则会抛出异常 TooManyResultsException ;但是若查询的数据只有一条,可以使用实体类或集合作为返回值

五、MyBatis获取参数值的两种方式(重点)

MyBatis 获取参数值的两种方式: ${} #{} ${} 的本质就是字符串拼接, #{} 的本质就是占位符赋值 ${} 使用字符串拼接的方式拼接 sql ,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引 号;但是 #{} 使用占位符赋值的方式拼接 sql ,此时为字符串类型或日期类型的字段进行赋值时,可以自 动添加单引号

1、单个字面量类型的参数

mapper 接口中的方法参数为单个的字面量类型 此时可以使用 ${} #{} 以任意的名称获取参数的值,注意 ${} 需要手动加单引号

2、多个字面量类型的参数

mapper 接口中的方法参数为多个时 此时 MyBatis 会自动将这些参数放在一个 map 集合中,以 arg0,arg1... 为键,以参数为值;以 param1,param2... 为键,以参数为值;因此只需要通过 ${} #{} 访问 map 集合的键就可以获取相对应的 值,注意 ${} 需要手动加单引号

3map集合类型的参数

mapper 接口中的方法需要的参数为多个时,此时可以手动创建 map 集合,将这些数据放在 map 只需要通过 ${} #{} 访问 map 集合的键就可以获取相对应的值,注意 ${} 需要手动加单引号

4、实体类类型的参数

mapper 接口中的方法参数为实体类对象时 此时可以使用 ${} #{} ,通过访问实体类对象中的属性名获取属性值,注意 ${} 需要手动加单引号

5、使用@Param标识参数

可以通过 @Param 注解标识 mapper 接口中的方法参数 此时,会将这些参数放在 map 集合中,以 @Param 注解的 value 属性值为键,以参数为值;以 param1,param2... 为键,以参数为值;只需要通过 ${} #{} 访问 map 集合的键就可以获取相对应的值, 注意 ${} 需要手动加单引号

 六、MyBatis的各种查询功能

1、查询一个实体类对象

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

2、查询一个list集合

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

3、查询单个数据

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

select count(id) from t_user

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

/*** 根据用户id查询用户信息为map集合 * @param id * @return */ Map getUserToMap(@Param("id") int id);
<!--Map getUserToMap(@Param("id") int id);-->select * from t_user where id = #{id} 

5、查询多条数据为map集合

方式一:

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

<!--Map getAllUserToMap();-->select * from t_user

方式二:

/*** 查询所有用户信息为map集合 * @return * 将表中的数据以map集合的方式查询,一条数据对应一个map;若有多条数据,就会产生多个map集合,并 且最终要以一个map的方式返回数据,此时需要通过@MapKey注解设置map集合的键,值是每条数据所对应的 map集合 */ @MapKey("id") Map getAllUserToMap();
<!--Map getAllUserToMap();-->select * from t_user 结果: 

七、特殊SQL的执行

1、模糊查询

/*** 测试模糊查询 * @param mohu * @return */ List testMohu(@Param("mohu") String mohu);

<!--List testMohu(@Param("mohu") String mohu);-->      select * from t_user where username like "%"#{mohu}"%"

2、批量删除

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

3、动态设置表名

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

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);
insert into t_user    values(null,#{username},#{password},#{age},#{sex})

八、自定义映射resultMap

1resultMap处理字段和属性的映射关系

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

                     <!--List testMohu(@Param("mohu") String mohu);-->  select id,user_name,password,age,sex from t_user where user_name like concat('%',#{mohu},'%')

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

2、多对一映射处理

查询员工信息以及员工所对应的部门信息

a>级联方式处理映射关系

                          select emp.*,dept.*from t_emp emp left join t_dept dept on emp.did = dept.did where emp.eid = #{eid}

 b>使用association处理映射关系

                            select emp.*,dept.*from t_emp emp left join t_dept dept on emp.did = dept.did where emp.eid = #{eid}

c> 分步查询 1 )查询员工信息

/*** 通过分步查询查询员工信息 * @param eid * @return */ Emp getEmpByStep(@Param("eid") int eid);
                          select* from t_emp where eid = #{eid}

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

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

3、一对多映射处理

a>collection

/*** 根据部门id查新部门以及部门中的员工信息 * @param did  * @return  */  Dept getDeptEmpByDid(@Param("did") int did);
                       select dept.*,emp.* from t_dept dept left join t_emp emp on dept.did = emp.did where dept.did = #{did}

b>分步查询

/*** 分步查询部门和部门中的员工 * @param did * @return */ Dept getDeptByStep(@Param("did") int did);
              select* from t_dept where did = #{did}

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

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

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

 

九、动态SQL

Mybatis 框架的动态 SQL 技术是一种根据特定条件动态拼装 SQL 语句的功能,它存在的意义是为了解决 拼接 SQL 语句字符串时的痛点问题。

1if

if 标签可通过 test 属性的表达式进行判断,若表达式的结果为 true ,则标签中的内容会执行;反之标签中的内容不会执行

<!--List getEmpListByMoreTJ(Emp emp);-->select * from t_emp where 1=1     and ename = #{ename}    and age = #{age}    and sex = #{sex}

2where

select * from t_emp     ename = #{ename} and age = #{age} and sex = #{sex}    

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

3trim

select * from t_emp     ename = #{ename} and age = #{age} and      sex = #{sex}     

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

4choosewhenotherwise

choose when otherwise 相当于 if...else if..else

<!--List getEmpListByChoose(Emp emp);-->select  from t_emp          ename = #{ename}     age = #{age}     sex = #{sex}     email = #{email}     

5foreach

<!--int insertMoreEmp(List emps);-->insert into t_emp values     (null,#{emp.ename},#{emp.age},#{emp.sex},#{emp.email},null)      delete from t_emp whereeid = #{eid}  delete from t_emp where eid in #{eid}

属性: collection :设置要循环的数组或集合 item :表示集合或数组中的每一个数据 separator :设置循环体之间的分隔符 open :设置 foreach 标签中的内容的开始符 close :设置 foreach 标签中的内容的结束符

6SQL片段

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

eid,ename,age,sex,did select  from t_emp

十、MyBatis的缓存

1MyBatis的一级缓存

一级缓存是 SqlSession 级别的,通过同一个 SqlSession 查询的数据会被缓存,下次查询相同的数据,就 会从缓存中直接获取,不会从数据库重新访问 使一级缓存失效的四种情况: 1) 不同的 SqlSession 对应不同的一级缓存 2) 同一个 SqlSession 但是查询条件不同 3) 同一个 SqlSession 两次查询期间执行了任何一次增删改操作 4) 同一个 SqlSession 两次查询期间手动清空了缓存

2MyBatis的二级缓存

二级缓存是 SqlSessionFactory 级别,通过同一个 SqlSessionFactory 创建的 SqlSession 查询的结果会被 缓存;此后若再次执行相同的查询语句,结果就会从缓存中获取 二级缓存开启的条件: a> 在核心配置文件中,设置全局配置属性 cacheEnabled="true" ,默认为 true ,不需要设置 b> 在映射文件中设置标签

c>二级缓存必须在SqlSession关闭或提交之后有效

d> 查询的数据所转换的实体类类型必须实现序列化的接口 使二级缓存失效的情况: 两次查询之间执行了任意的增删改,会使一级和二级缓存同时失效

3、二级缓存的相关配置

mapper 配置文件中添加的 cache 标签可以设置一些属性: eviction 属性:缓存回收策略 LRU Least Recently Used 最近最少使用的:移除最长时间不被使用的对象。 FIFO First in First out 先进先出:按对象进入缓存的顺序来移除它们。 SOFT – 软引用:移除基于垃圾回收器状态和软引用规则的对象。 WEAK – 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象。 默认的是 LRU flushInterval 属性:刷新间隔,单位毫秒 默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新 size 属性:引用数目,正整数 代表缓存最多可以存储多少个对象,太大容易导致内存溢出 readOnly 属性:只读, true/false true :只读缓存;会给所有调用者返回缓存对象的相同实例。因此这些对象不能被修改。这提供了 很重要的性能优势。 false :读写缓存;会返回缓存对象的拷贝(通过序列化)。这会慢一些,但是安全,因此默认是 false

4MyBatis缓存查询的顺序

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

5、整合第三方缓存EHCache

a>添加依赖

    org.mybatis.caches    mybatis-ehcache    1.2.1  ch.qos.logbacklogback-classic1.2.3

b>jar包功能

 

c>创建EHCache的配置文件ehcache.xml

         

d>设置二级缓存的类型

e>加入logback日志

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

                            [%d{HH:mm:ss.SSS}] [%-5level] [%thread] [%logger] [%msg]%n                   

f>EHCache配置文件说明

 

十一、MyBatis的逆向工程

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

1、创建逆向工程的步骤

a>添加依赖和插件

     org.mybatis mybatis 3.5.7             org.mybatis.generator mybatis-generator-maven-plugin 1.3.0          org.mybatis.generator  mybatis-generator-core  1.3.2             com.mchange  c3p0  0.9.2             mysql  mysql-connector-java  5.1.8          

b>创建MyBatis的核心配置文件

c>创建逆向工程的配置文件

文件名必须是: generatorConfig.xml

                                             

d>执行MBG插件的generate目标

 

效果:

 

2QBC查询

  @Test    public void testMBG() throws IOException { InputStream is = Resources.getResourceAsStream("mybatis-config.xml"); SqlSession sqlSession = new SqlSessionFactoryBuilder().build(is).openSession(true); EmpMapper mapper = sqlSession.getMapper(EmpMapper.class); EmpExample empExample = new EmpExample(); //创建条件对象,通过andXXX方法为SQL添加查询添加,每个条件之间是and关系  empExample.createCriteria().andEnameLike("a").andAgeGreaterThan(20).andDidIsNot Null();  //将之前添加的条件通过or拼接其他条件 empExample.or().andSexEqualTo("男");  List list = mapper.selectByExample(empExample);  for (Emp emp : list) { System.out.println(emp); } }    }

十二、分页插件

1、分页插件使用步骤

a>添加依赖

    com.github.pagehelper    pagehelper    5.2.0

b>配置分页插件

MyBatis 的核心配置文件中配置插件

     

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]

注:本文章来自尚硅谷2022最新mybatis教程,如文章中有疑问,可以结合视频一起看