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>

实验结果

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

相关推荐
代码之光_198011 分钟前
保障性住房管理:SpringBoot技术优势分析
java·spring boot·后端
鹿屿二向箔40 分钟前
基于SSM(Spring + Spring MVC + MyBatis)框架的咖啡馆管理系统
spring·mvc·mybatis
戴眼镜的猴1 小时前
Spring Boot的过滤器与拦截器的区别
spring boot
尘浮生2 小时前
Java项目实战II基于Spring Boot的光影视频平台(开发文档+数据库+源码)
java·开发语言·数据库·spring boot·后端·maven·intellij-idea
尚学教辅学习资料2 小时前
基于SpringBoot的医药管理系统+LW示例参考
java·spring boot·后端·java毕业设计·医药管理
morris1313 小时前
【SpringBoot】Xss的常见攻击方式与防御手段
java·spring boot·xss·csp
阿伟*rui6 小时前
配置管理,雪崩问题分析,sentinel的使用
java·spring boot·sentinel
XiaoLeisj8 小时前
【JavaEE初阶 — 多线程】单例模式 & 指令重排序问题
java·开发语言·java-ee
paopaokaka_luck8 小时前
【360】基于springboot的志愿服务管理系统
java·spring boot·后端·spring·毕业设计
Yaml410 小时前
Spring Boot 与 Vue 共筑二手书籍交易卓越平台
java·spring boot·后端·mysql·spring·vue·二手书籍