MyBatis

SpringBoot整合Mybatis

1.1.ORM思想:


对象关系映射(英语:Object Relational Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序设计技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。

总结: 以面向对象的方式操作数据库.
知识升华:
1. 以对象的方式实现数据库CRUD操作.
2. 要求通过某种机制将对象动态的转化为Sql,之后实现数据库操作.(自己不写Sql)

1.2.Mybatis优点/缺点


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

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

1.3. MybatisPlus介绍


MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

2.步骤:

2.1.导包:

    <!--引入数据库驱动 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

        <!--springBoot数据库连接  -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>

        <!--spring整合mybatis  暂时  -->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.2.0</version>
        </dependency>

<!--spring整合mybatis-plus-->(maybatis-plus与mybatis之间只能存在一个包,两个包同时存在会报错)
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.3</version>
        </dependency>

2.实现映射(映射两个代码一一对应,有关系列:978=a;a=978)

关键词: 对象 表 属性 字段 一一映射.
说明:
1.对象名称与表的名称一一对应.
2.对象的属性与表中的字段一一对应.

创建一个类:实现映射切有接口

@Data
@Accessors(chain = true)
//1.将对象与表进行关联
//规则:1.如果表名与对象名一致,名称可以省略
//2.字段名与属性名一致,则“注解”可以省略
@TableName("demo_user")
//Serializable序列化:保证网络传输的有效性
public class User implements Serializable {
    //2.Id代表主键(不是名),主键自增/非空/UUID(生成唯一编号)
    @TableId(type = IdType.AUTO)
    private Integer id;
    //3.标识属性与字段的映射
    //@TableId("name")
    private String name;
    private Integer age;
    private String sex;

}

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.mapper.UserMapper">

    <!--id=方法名,resultType=类的径路  -->
    <select id="findAll" resultType="com.jt.pojo.User">
        select * from demo_user
    </select>

</mapper>

4.继承特定接口

package jt.dao;

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

import java.util.List;
import java.util.stream.BaseStream;

public interface UserMapper extends BaseMapper<User> {
    List<User> findAll();
}

5.编辑yml文件(application.yml)

#端口配置
server:
  port: 8090

#配置数据源
spring:
  datasource:
    #如果使用高版本驱动 则添加cj
    driver-class-name: com.mysql.cj.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: 3306

#Spring整合My
mybatis-plus:
  #定义别名包
  type-aliases-package: com.jt.pojo
  #导入映射文件
  mapper-locations: classpath:/mappers/*.xml
  #开启驼峰映射
  configuration:
    map-underscore-to-camel-case: true

6.测试文件(注意test测试文件要在RunApp的子包,)

package jt.test1;

import jt.dao.UserMapper;
import 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);
        System.out.println("入库操作成功");
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值