Mybatis轻松入门,一篇就够

本文详述了MyBatis的基本概念、历史、特点及下载方式,并逐步讲解了如何搭建MyBatis环境,包括创建核心配置文件、mapper接口、映射文件,以及通过JUnit测试。还介绍了MyBatis的参数获取方式、查询功能、特殊SQL操作、自定义映射ResultMap、动态SQL、缓存机制、逆向工程和分页插件的使用,旨在帮助开发者全面理解并快速上手MyBatis。
摘要由CSDN通过智能技术生成

目录

1、MyBatis简介

1.0、MyBatis是什么

1.1MyBatis历史

1.2、MyBatis特性

1.3、MyBatis下载

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

2、搭建MyBatis

2.1、开发环境

2.2、创建maven工程

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获取参数值的两种方式

${}和#{}的区别

1、符号类型

2、防注入问题

3、sql执行过程

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

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

5.3、map集合类型的参数

5.4、实体类类型的参数

5.5、使用@Param标识参数

MyBatis获取参数值总结

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、分步查询

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、分页插件的使用


1、MyBatis简介

1.0、MyBatis是什么

MyBatis 是一个 半自动的ORM(Object Relation Mapping)(对象关系映射)框架

对象:Java的实体类对象

关系:关系型数据库

映射:二者之间的对应关系

Java概念 数据库概念
属性 字段名(列)
对象 (一个对象对应着数据库中表的一行数据) 记录/行一行

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

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)(对象关系映射)框架

对象:Java的实体类对象

关系:关系型数据库

映射:二者之间的对应关系

Java概念 数据库概念
属性 字段名(列)
对象 (一个对象对应着数据库中表的一行数据) 记录/行一行

5)MyBatis 是直接面向接口编程的,不用实现实现类

通过代理模式创建UserMapper接口的代理实现类对象,mybatis是直接面向接口编程
UserMapper mapper = sqlSession.getMapper(UserMapper.class);

1.3、MyBatis下载

MyBatis下载地址:GitHub - mybatis/mybatis-3: MyBatis SQL mapper framework for Java

 

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"/>
            <!--    装配druid的数据源   数据源:管理数据库的链接的-->
            <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();
​
    //修改用户信息
    void updateUser();
​
    //删除用户信息
    void deleteUser();
​
    //根据id查询用户信息
    User getUserById();
​
    //查询所有的用户信息
    List<User> getAllUser();
}

2.5、创建MyBatis的映射文件

相关概念:ORMObject 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">
​
    <!--
    MyBatis中可以面向接口操作数据,要保证两个一致:
    a>mapper接口的全类名和映射文件的命名空间(namespace)保持一致
    b>mapper接口中方法的方法名和映射文件中编写SQL的标签的id属性保持一致
    -->
<mapper namespace="com.yka.mybatis.mapper.UserMapper">
    <!--int insertUser();-->
    <insert id="insertUser">
        insert into t_user values(null,'admin','123456',23,'男','12345@qq.com')
    </insert>
​
    <!--void updateUser();-->
    <update id="updateUser">
        update t_user set username = 'root',password = '123' where id = 3;
    </update>
​
    <!--void deleteUser();-->
    <delete id="deleteUser">
        delete from ssm.t_user where id = 4
    </delete>
​
    <!--
        查询的标签select必须设置属性resultType或resultMap,用于设置实体类和数据库表的映射关系
        resultType:自动映射,用于属性名和表中字段名一致的情况,查询的数据结果要转化为Java类型
        resultMap:自定义映射,用于一对多或多对一或字段名和属性名不一致的情况
    -->
​
    <!--User getUserById();-->
    <select id="getUserById" resultType="com.yka.mybatis.pojo.User">
        select * from ssm.t_user where id = 1;
    </select>
​
    <!--List<User> getAllUser();-->
    <select id="getAllUser" resultType="com.yka.mybatis.pojo.User">
        select * from ssm.t_user;
    </select>
</mapper>

2.6、通过junit测试功能

先创建工具类SqlSessionUtil,简化以下测试类的代码

public class SqlSessionUtil {
    public static SqlSession getSqlSession(){
            SqlSession sqlSession = null;
        try {
            //获取核心配置文件的输入流
            InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
            //获取SqlSessionFactoryBuilder
            SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
            //通过核心配置文件所对应的字节输入流创建工厂类SqlSessionFactory,生产SqlSession对象
            SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
            //获取SqlSession对象
            sqlSession = sqlSessionFactory.openSession(true);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return sqlSession;
    }
}
public class MybatisTest {
​
    //新增
    @Test
    public void testInsert() throws IOException {
        //获取核心配置文件的输入流
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
        System.out.println(is);
​
        //获取SqlSessionFactoryBuilder对象
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
        System.out.println(sqlSessionFactoryBuilder);
​
        //通过核心配置文件所对应的字节输入流创建工厂类SqlSessionFactory,生产SqlSession对象
        SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
        System.out.println(sqlSessionFactory);
​
        //获取sql的会话对象SqlSession(不会自动提交事物),是MyBatis提供的操作数据库的对象
        //SqlSession sqlSession = sqlSessionFactory.openSession();
        //获取sql的会话对象SqlSession(true会自动提交事物),是MyBatis提供的操作数据库的对象
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
​
        //两种写法执行sql语句的,第二种不常用了解就行
        //第一种:通过代理模式 创建UserMapper接口的代理实现类对象 ,mybatis直接面向接口编程
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        System.out.println(mapper);
        //调用UserMapper接口中的方法,就可以根据UserMapper的全类名匹配映射文件,通过调用的方法名匹配映射文件中的SQL标签的       id,并执行标签中的SQL语句
        int result = mapper.insertUser();
​
        //第二种:提交sql以及的唯一标识找到sql并执行,唯一标识是映射文件中 两个标签属性:namespace.splId
        //int result = sqlSession.insert("com.yka.mybatis.mapper.UserMapper.insertUser");
        System.out.println("结果:"+result);
        //提交事物
//        sqlSession.commit();
        //关闭sqlSession
        sqlSession.close();
    }
​
    //修改
    @Test
    public void testUpdate(){
        //调用SqlSessionUtil工具类的方法
        SqlSession sqlSession = SqlSessionUtil.getSqlSession();
        //通过代理模式创建UserMapper接口的代理实现类对象,mybatis直接面向接口编程
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        //调用UserMapper接口中的方法,就可以根据UserMapper的全类名匹配映射文件中的namespace属性,通过调用的方法名与映射文件       中的SQL标签的id匹配,并执行标签中的SQL语句
        mapper.updateUser();
        sqlSession.close();
    }
​
    //删除
    @Test
    public void testDelete(){
        //调用SqlSessionUtil工具类的方法
        SqlSession sqlSession = SqlSessionUtil.getSqlSession();
        //通过代理模式创建UserMapper接口的代理实现类对象,mybatis直接面向接口编程
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        System.out.println(mapper);
        //调用UserMapper接口中的方法,就可以根据UserMapper的全类名匹配映射文件中的namespace属性,通过调用的方法名与映射文件       中的SQL标签的id匹配,并执行标签中的SQL语句
        mapper.deleteUser();
        sqlSession.close();
    }
​
    //根据id查询
    @Test
    public void testGetUserById(){
        //调用SqlSessionUtil工具类的方法
        SqlSession sqlSession = SqlSessionUtil.getSqlSession();
        //通过代理模式创建UserMapper接口的代理实现类对象,mybatis直接面向接口编程
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        System.out.println(mapper);
        //调用UserMapper接口中的方法,就可以根据UserMapper的全类名匹配映射文件中的namespace属性,通过调用的方法名与映射文件       中的SQL标签的id匹配,并执行标签中的SQL语句
        User user = mapper.getUserById();
        System.out.println(user);
        sqlSession.close();
    }
​
    //查询所有用户信息
    @Test
    public void testGetAllUser(){
        //调用SqlSessionUtil工具类的方法
        SqlSession sqlSession = SqlSessionUtil.getSqlSession();
        //通过代理模式创建UserMapper接口的代理实现类对象,mybatis直接面向接口编程
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        System.out.println(mapper);
        //调用UserMapper接口中的方法,就可以根据UserMapper的全类名匹配映射文件中的namespace属性,通过调用的方法名与映射文件       中的SQL标签的id匹配,并执行标签中的SQL语句
        List<User> list = mapper.getAllUser();
        list.forEach(v->{
            System.out.println(v);
        });
        System.out.println(list);
        sqlSession.close();
    }
​
}
  • 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、核心配置文件详解

配置jdbc.properties文件

jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ssm?serverTimezone=UTC
jdbc.username=root
jdbc.password=123456

核心配置文件中的标签必须按照固定的顺序:

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文件,此后就可以在当前文件中使用${key}的方式访问value-->
    <properties resource="jdbc.properties" />
 
    <!--
     typeAliases:设置类型别名,即为某个具体的类型设置一个别名
     在MyBatis的范围中,就可以使用别名表示一个具体的类型,
     在映射文件中select标签中resultType属性中可以用别名来表示
 -->
    <typeAliases>
    <!--
        typeAlias:设置某个类型的别名
        属性:
            type:设置需要设置别名的类型
            alias:设置某个类型的别名,若不设置该属性,那么该类型拥有默认的别名,就是类名且不区分大小写
    -->
        <!--<typeAlias type="com.atguigu.mybatis.pojo.User"></typeAlias>-->
        <!--以包为单位,将包下所有的类型设置默认的类型别名,就是类名且不区分大小写-->
        <package name="com.yka.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"/>
       
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值