javaee实验:Spring Boot 整合 Mybatis

目录

Mybatis

MyBatis 框架简介

Mybatis 的前身是 Apache 的开源框架 iBatis,与 Hibernate 一样是一个 Java 持久层的框

架。Mybatis 的优势在于灵活,它几乎可以替代 JDBC,同时提供了接口编程。目前 Mybatis

的数据访问层 DAO(Data Access Object)是不需要实现类的,它只需要一个接口和 XML(或

者注解)。Mybatis 提供自动映射,动态 SQL,级联,缓存,注解,代码和 SQL 分离等特性,

使用方便,同时也对 SQL 进行优化。因为其具有封装少,映射多样化,支持存储过程,可

以进行 SQL 优化等特点,使得它取代了 Hibernate 成为 Java 互联网中首选持久层框架。

Mybatis 在完成其功能的过程中,主要完成两件事情:

1)封装 JDBC 操作;

2)利用反射打通 Java 类和 sql 语句之间的关系。

Mybatis 框架的建立是为了解决传统 JDBC 连接数据库中存在的大量编码问题。Mybatis

可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 中的普通对象映射成数

据库中的记录

Mybatis 框架执行流程图

SqlSession 去执行操作查询数据库映射文件,用途:

1)获取映射器,让映射器通过命名空间和方法名称找到对应的 SQL,发送给数据库,执

行后返回结果。

2)直接通过命名信息去执行 SQL 返回结果。

映射器

MyBatis 框架包括两种类型的 XML 文件,一类是配置文件,即 mybatis-config.xml,另外

一类是映射文件,例如 XXXMapper.xml 等。在 MyBatis 的配置文件 mybatis-config.xml 包含了

节点,这里就是 MyBatis 映射器。

  1. MyBatis 映射器分为三类,如下所示:
    (1)纯 XML 映射器,利用 SqlSession 的各种方法实现增删改查。例如:
    Person p = session.selectOne("cn.mybatis.mydemo.mapper.PersonMapper.selectPersonById", 1);
    (2)XML 映射器+接口映射器的混合类型
    先定义接口映射器,然后再定义 xml 映射器,其中 xml 映射器的 namespace 应该对应接
    口映射器的类名。
    (3)注解+接口映射器的混合形式
    此类形式,将原先 xml 里面的 sql 配置信息,变成 Java 注解的形式写到接口映射器,用
    法与上面的例子雷同。
  2. XML 映射器+接口映射器的混合类型
    映射器由 Java 接口和 XML 文件(或注解)共同组成,它的作用:
     定义参数类型
     描述缓冲描述
     SQL 语句定义
     查询结果和 POJO 的映射关系
    实例:先定义一个映射器接口,如下所示
java 复制代码
public interface StudentMapper {
 public Student getStudent(Long id);
}

注意:映射器只是一个接口,而不是一个实现类。初学者可能会产生一个很大的疑问:

接口不是不能运行吗?的确,接口不能直接运行,但是 MyBatis 内部运用了动态代理技术,

生成接口的实现类,从而完成接口的相关功能。只要明白 MyBatis 会为这个接口生成一个

代理对象,代理对象会去处理映射器接口相关的逻辑即可。

然后,用 XML 方式创建映射器,如下所示:

<?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="cn.mybatis.mydemo.mapper.StudentMapper">
 <select id="getStudent" parameterType="long" resultType="student">
 SELECT id,name,address FROM Student WHERE id =#{id}
 </select>
</mapper>

有了这两个文件,就完成了一个映射器的定义。关于 XML 文件内容介绍,如下所示:

(1) 元素中的属性 namespace 所对应的是一个接口的全限定名,于是

MyBatis 上下文就可以通过它找到对应的接口。

3

(2) 元素表明这是一条查询语句,而属性 id 标识了这条 SQL,属性

parameterType="long" 说明传递给 SQL 的是一个 long 型的参数,而 resultType="student"

表示返回的是一个 Student 类型的返回值。而 student 是配置文件 mybatis-config.xml 配置

的别名,指代的是 com.mybatis.domain.Student。这条 SQL 中的 #{id} 表示传递进去的参数

实验目的

(1) 掌握 Mybatis 框架的基本构成

(2) 掌握如何在 Spring Boot 中集成 Mybatis 框架

(3) 掌握 Mybatis 框架实现查询等操作方法

实验内容

Spring Boot 集成 Mybatis 框架实现用户信息的增删改查操作

实验过程

数据库准备

在mysql中准备一个有username并且内容不是中文的表

实例如下

sql 复制代码
CREATE TABLE `t_user` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `user_name` varchar(32) NOT NULL COMMENT '用户名称',
 `note` varchar(256) DEFAULT NULL COMMENT '备注',
 PRIMARY KEY (`id`)
)

录入数据

项目结构

代码实现

IUserDao

java 复制代码
import java.util.List;

/**
 * @author hongjun
 * @create 2020-10-28 17:27
 */
public interface IUserDao {

    /*
    * 查询所有用户信息
    * */
    List<User> findAll();
}

IUserDaoImpl

java 复制代码
import com.example.mybatis1.domain.User;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;

import java.util.List;

/**
 * @author hongjun
 * @create 2020-11-01 9:49
 */
public class IUserDaoImpl  implements IUserDao{
    private SqlSessionFactory sqlSessionFactory;
    public IUserDaoImpl(SqlSessionFactory sqlSessionFactory){
        this.sqlSessionFactory=sqlSessionFactory;
    }
    @Override
    public List<User> findAll() {
       SqlSession sqlSession= sqlSessionFactory.openSession();
       List<User> userList=sqlSession.selectList("com.example.mybatis1.dao.IUserDao.findAll");
       sqlSession.close();
        return userList;
    }
}

User

java 复制代码
import lombok.Data;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

/**
 * @author hongjun
 * @create 2020-08-24 15:28
 *  id                   bigint not null,
 *     dept_id              bigint,
 *     username             varchar(20),
 *     password             varchar(50),
 *     realname             varchar(10),
 *     sex                  varchar(10),
 *     telephone            varchar(30),
 *     email                varchar(200),
 *     avatar               varchar(300),
 *     job_title            varchar(30),
 *     status               tinyint,
 *     sort                 int,
 *     del_flag             int comment '0 未删除 1 已删除',
 *     create_time          datetime,
 *     create_by            varchar(20),
 *     update_time          datetime,
 */
@Data
public class User {
   private Integer id;
   private Integer dept_id;
   private String username;
   private String password;
   private String realname;
   private String sex;
   private String telephone;
   private String email;
   private String avastar;
   private String jobTitle;
   private Integer status;
   private Integer sort;
   private Integer delFlag;
   private Date createTime;
   private Date updateTime;
   private String createBy;
}

IUserDao.xml

java 复制代码
<?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.example.mybatis1.dao.IUserDao">
    <select id="findAll" resultType="com.example.mybatis1.domain.User">
        select * from user
    </select>
</mapper>

SqlMapConfig.xml

java 复制代码
<?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="mysql">
        <!--配置mysql环境-->
        <environment id="mysql">
            <!--配置事务-->
            <transactionManager type="JDBC"></transactionManager>
            <!--配置连接池-->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/stu?serverTimezone=Asia/Shanghai"/>
                <property name="username" value="root"/>
                <property name="password" value="password"/>
            </dataSource>
        </environment>
    </environments>
    <!--配置映射文件的位置-->
    <mappers>
        <!--配置文件方式,每一个映射文件所在的地方-->
        <mapper resource="com/example/mybatis1/dao/IUserDao.xml"></mapper>
        <!--注解方式-->
       <!-- <mapper class="nuc.edu.mybatis.dao.IUserDao"></mapper>-->
    </mappers>

</configuration>

实验结果

如图所示,已经查询了出来

相关推荐
paopaokaka_luck7 分钟前
[371]基于springboot的高校实习管理系统
java·spring boot·后端
捂月1 小时前
Spring Boot 深度解析:快速构建高效、现代化的 Web 应用程序
前端·spring boot·后端
FIN技术铺4 小时前
Spring Boot框架Starter组件整理
java·spring boot·后端
小码的头发丝、4 小时前
Spring Boot 注解
java·spring boot
午觉千万别睡过4 小时前
RuoYI分页不准确问题解决
spring boot
2301_811274314 小时前
大数据基于Spring Boot的化妆品推荐系统的设计与实现
大数据·spring boot·后端
编程重生之路5 小时前
Springboot启动异常 错误: 找不到或无法加载主类 xxx.Application异常
java·spring boot·后端
politeboy5 小时前
k8s启动springboot容器的时候,显示找不到application.yml文件
java·spring boot·kubernetes
Theodore_102210 小时前
4 设计模式原则之接口隔离原则
java·开发语言·设计模式·java-ee·接口隔离原则·javaee