2021-08-23 SpringBoot 整合Mybatis MybatisPlus学习

1.1跳过测试类打包

需求说明:maven执行打包命令时,默认条件下会执行测试类中的方法,测试方法中一旦报错,则install的操作执行失败

解决方案: 要求install时 不要执行test方法。

解决方案:跳过测试类打包

   <properties>
        <!--指定JDK版本-->
        <java.version>1.8</java.version>
        <!--跳过测试类打包-->
        <skipTests>true</skipTests>
    </properties>

1.2创建项目。

对demo_user数据进行增删改查

1创建maven工程

2.导入pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.jt</groupId>
    <artifactId>demo</artifactId>
    <version>1.0-SNAPSHOT</version>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.5.3</version>
        <relativePath/>
    </parent>

    <dependencies>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <!--Springboot的启动器 在内部已经将整合的配置写好,实现拿来就用-->
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>


        <!--支持热部署 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
        </dependency>

        <!--引入插件lombok 自动的set/get/构造方法插件  -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.2.0</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.48</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
            <version>2.5.3</version>
        </dependency>


    </dependencies>

</project>

编辑主启动类

Spring管理Mapper接口(方式一)

说明: @Mapper注解 一般标识接口中. 如果有多个接口,则应该标识多次.
优化: 可以采用 @MapperScan(“xxxx”)进行优化.

 

Spring管理Mapper接口(方式二)

package com.jt;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
@MapperScan("com.jt.dao")
public class Runapp {
    public static void main(String[] args) {
        SpringApplication.run(Runapp.class, args);
    }
}

数据库

        

 1.4 整合mybatis

//序列化接口的作用:保证对象网络传输的有效性

package com.jt.pojo;

import lombok.Data;
import lombok.experimental.Accessors;

import java.io.Serializable;

@Data
@Accessors(chain = true)
public class User implements Serializable {
 private Integer id;
 private String name;
 private Integer age;
 private String sex;
}

1.4.2 编辑YML文件

编辑 1.数据源 2.整合mybatis

#端口配置
server:
  port: 8080

#配置数据源
spring:
  datasource:
    #如果使用高版本驱动 则添加cj
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/jt?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true
    username: root
    password: root

#Spring整合Mybatis
mybatis:
  #定义别名包
  type-aliases-package: com.jt.pojo
  #导入映射文件
  mapper-locations: classpath:/mappers/*.xml
  #开启驼峰映射
  configuration:
    map-underscore-to-camel-case: true
  • 数据库配置参数:
  • 1.serverTimezone=GMT%2B8& 时区
  • 2.useUnicode=true& 是否使用unicode编码
  • 3.characterEncoding=utf8& 字符集使用utf-8
  • 4.autoReconnect=true& 自动重连
  • 5.allowMultiQueries=true 运行批量操作

1.4.3 编辑映射文件

<?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.jt.dao.UserMapper">
   <!--查询全表-->
    <select id="getlist" resultType="User">
        select * from demo_user
    </select>
<!--按照id删除-->
    <delete id="delete">
        delete from demo_user where id=#{id}
    </delete>
    <!--增加记录-->
    <insert id="insert">
        insert into demo_user values (#{id},#{name},#{age},#{sex})
    </insert>

    <!--修改-->
    <update id="update">
        update demo_user set name=#{newname} where id=#{id}
    </update>
</mapper>

 编辑测试类

package com.jt.test;

import com.jt.dao.UserMapper;
import com.jt.pojo.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.List;

@SpringBootTest
public class Test {
    @Autowired
    private UserMapper userMapper;
    @org.junit.jupiter.api.Test
    public void test(){
        List<User> getlist = userMapper.getlist();
        System.out.println(getlist);
       //删除
        userMapper.delete(233);
        //增加
        User user = new User().setId(null).setName("HANY").setAge(156).setSex("女");
        userMapper.insert(user);
        //更新
        userMapper.update(234, "eafhf");
    }

}

 Bug

说明: 通过包扫描的路径,在运行期间实现对象的创建. 实现了数据的绑定.所以下边的红线属于误报…

解决方案

在这里插入图片描述

 说明: 如果xml的映射文件,则根目录下(不建议), 则加载时采用classpath*😕*.xml的结构.
强制加载根目录下的所有的xml文件.

放在文件夹下

 2. MybatisPlus学习

ORM思想,对象关系映射(object Relational Mapping),是一种程序设计技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换

面向对象的方式来操作数据库!

以对象的方式实现数据库CRUD操作

要求通过某种机制将对象动态的转换为sql,之后实现数据库的操作,可以不写sql语句

2.2 Mybatis优点/缺点

优点:
1.Mybatis 内部整合了JDBC, 简化了持久层开发.
2.Mybatis可以自动的封装结果集的对象 满足ORM中的一个条件.所以将Mybatis称之为半自动化的ORM映射框架.
3.Mybatis有缓存机制 一级缓存/二级缓存.提高用户得查询效率.
4.Mybatis支持多种类型的数据库. 整合简单.

缺点:
1.实现数据的封装 resultMap 封装复杂!!!
2.针对于单表的CRUD的操作 不够便捷. Sql都需要手写!!!
3.个别的情况下二级缓存配置不生效!!!
 

2.4 MP入门案例(数据库表同上

第一,导入jar包更换原有mybatis

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.4.3</version>
</dependency>

2.4.2 实现映射

在这里插入图片描述

 

关键在于继承特定的接口

关键词: 封装—多态—继承
说明: MP在内部准备一个BaseMapper的接口 BaseMapper内部几乎将单表的CURD操作 都进行了编辑. 用户自己的Mapper接口可以继承即可.

package com.jt.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.jt.pojo.User;

import java.util.List;

//@Mapper将该接口交给Spring管理
public interface UserMapper extends BaseMapper<User> {
    List<User> get();
}

第三步 yml文件中mybatis改成

mybatis-plus:

最后可以进行测试:!!!

package com.jt.test;

import com.jt.mapper.UserMapper;
import com.jt.pojo.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
public class TestMP {
    @Autowired
    private UserMapper userMapper;
    @Test
    public void test01(){
       //增加
        User user = new User();
        user.setName("阿富汗").setAge(40).setSex("厉害");
        userMapper.insert(user);
       //查询
        User user1 = userMapper.selectById(21);
        System.out.println(user1);
    }
}

分析问题: 对象如何转化为Sql.

核心理论

.例子: userMapper.insert(user);
dogMapper.insert(dog);

关键在转化

Sql:
1. insert into 表名(字段名称…) value (属性的值…)

总结: MP将常规的操作进行抽取, 采用公共的接口进行定义. 之后只需要按照用户的参数, 动态的拼接Sql即可.
重点: 对java反射机制 有一定的了解

  1. userMapper.insert(user);
    用户传入user对象,通过对象.getclass()获取类型
  2. 根据class的类型,通过反射动态获取指定的注解@TableName("demo_user"),得到表tableName.value();
  3. 根据class的类型,知道其属性,由属性名称获取注解,获取到表字段的名称@TableField(“name”),
  4. 最终拼接出完整的sql语句
  5. 最终将Sql 由MP交给Mybatis执行sql. 最终实现数据的入库操作.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值