欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SpringBoot_02通用mapper

程序员文章站 2023-11-25 23:54:46
注意:一旦引入了通用Mapper的启动器,会覆盖Mybatis官方启动器的功能,因此需要移除对官方Mybatis启动器的依赖。 无需任何配置就可以使用了。如果有特殊需要,可以到通用mapper官网查看:https://github.com/abel533/Mapper/wiki/3.config 通 ......

 

注意:一旦引入了通用mapper的启动器,会覆盖mybatis官方启动器的功能,因此需要移除对官方mybatis启动器的依赖。

无需任何配置就可以使用了。如果有特殊需要,可以到通用mapper官网查看:https://github.com/abel533/mapper/wiki/3.config

通用mapper不需要dao层的xml文件,只需要dao层的接口继承mapper接口

 

总结使用步骤

整合通用mapper的使用:

第一步:  如果使用通用mapper就需要把mybatis的依赖和配置全部去掉 包括jar、xml、引导类上的mapperscan

 

第二步:添加通用mapper的启动器

   <dependency>

            <groupid>tk.mybatis</groupid>

            <artifactid>mapper-spring-boot-starter</artifactid>

            <version>2.1.5</version>

        </dependency>

第三步:修改pojo实体类

  在类名上添加一个注解@table(name="表名") 用于表和实体类的映射关系

  在注解上添加一个@id  表名是主键

第四步:修改dao,让dao的接口继承一个父接口mapper<t> ,默认就有了crud方法

 

第五步:修改service实现类中dao的方法 userdao.selectbyprimarykey(id)

 

一.和整合mybatis的区别

 

  1. 不需要编写xml文件,
  2. 更改引导类上的@mapperscan注解,改成通用mapper的
  3. 不需要在application.yml文件上对 通用mapper 进行配置
  4. dao层的接口需要实现mapper<对应的实体类>接口
  5. 实体类需要使用注解告诉通用mapper谁是主键,该实体类对应的表是谁

 

二.通用mapper的使用

1.    导入启动器(坐标)

 

<!-- 通用mapper -->

<dependency>

    <groupid>tk.mybatis</groupid>

    <artifactid>mapper-spring-boot-starter</artifactid>

    <version>2.1.5</version>

</dependency>

 

将通用mapper的坐标替换成mybatis的

 

完整坐标:

    <dependencies>
        <!--通过项目模板,已经自动配置上了springmvc启动器,lombok启动器和test启动器-->
        <!--项目模板自动配置 开始-->
       
<dependency>
            <groupid>org.springframework.boot</groupid>
            <artifactid>spring-boot-starter-web</artifactid>
        </dependency>

        <dependency>
            <groupid>org.projectlombok</groupid>
            <artifactid>lombok</artifactid>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupid>org.springframework.boot</groupid>
            <artifactid>spring-boot-starter-test</artifactid>
            <scope>test</scope>
        </dependency>
        <!--项目模板自动配置 结束-->

        <!--配置springboot整合mybatis 开始-->
        <!--配置mybatis 开始-->
<!--        <dependency>
            <groupid>org.mybatis.spring.boot</groupid>
            <artifactid>mybatis-spring-boot-starter</artifactid>
            <version>2.0.1</version>
        </dependency>-->
        <!-- 通用mapper -->
       
<dependency>
            <groupid>tk.mybatis</groupid>
            <artifactid>mapper-spring-boot-starter</artifactid>
            <version>2.1.5</version>
        </dependency>
        <!--配置通用mapper 结束-->
        <!--配置jdbc 开始-->
            <!--spring中的jdbc连接和事务是配置中的重要一环,在springboot中该如何处理呢?
            我们只要找到springboot提供的启动器即可:
             -->
       
<dependency>
            <groupid>org.springframework.boot</groupid>
            <artifactid>spring-boot-starter-jdbc</artifactid>
        </dependency>
        <!--配置jdbc 结束-->
        <!--配置mysql 开始-->
       
<dependency>
            <groupid>mysql</groupid>
            <artifactid>mysql-connector-java</artifactid>
            <version>5.1.47</version>
        </dependency>
        <!--配置mysql 结束-->
        <!--配置druid连接池 开始-->
       
<dependency>
            <groupid>com.alibaba</groupid>
            <artifactid>druid</artifactid>
            <version>1.1.6</version>
        </dependency>
        <!--配置druid连接池 结束-->
        <!--配置springboot整合mybatis 结束-->


   
</dependencies>

 

 

 

2.    在引导类上添加注解@mapperscan

 SpringBoot_02通用mapper

 

 

 

 

注意导的包的路径

 

 

3.    编辑实体类

 

package com.ahd.pojo;

import lombok.data;
import tk.mybatis.mapper.annotation.keysql;

import javax.persistence.id;
import javax.persistence.table;
import java.util.date;

@data   //lombok的注解,在工程编译时自动为实体类添加上get,set,...方法
@table(name="tb_user")  //告诉通用`mapper对应的数据库表的名字
public class user {
    // id
    @id //告诉通用mapper 谁是主键
    @keysql(usegeneratedkeys = true) //开启自增主键回显功能
    private long id;
    // 用户名
    private string username;
    // 密码
    private string password;
    // 姓名
    private string name;
    // 年龄
    private integer age;
    // 性别,1男性,2女性
    private integer sex;
    // 出生日期
    private date birthday;
    // 创建时间
    private date created;
    // 更新时间
    private date updated;
    // 备注
    private string note;
}

 

4.    application.yml配置文件

 

spring:
  datasource:
    type: com.alibaba.druid.pool.druiddatasource
    username: root
    url: jdbc:mysql:///saas-export-96
    password: 123456
    driver-class-name: com.mysql.jdbc.driver
#mybatis:
#  configuration:
#    map-underscore-to-camel-case: true
#  type-aliases-package: com.ahd.pojo
#  mapper-locations: /mapper/**

 

 

5.    编写dao层接口

package com.ahd.dao;

import com.ahd.pojo.user;
import tk.mybatis.mapper.common.mapper;

public interface userdao extends mapper<user>{//添加泛型,告知通用mapper实体类是谁
}

 

 

 

6.    说明

自己编写的dao层继承mapper接口,userdao会继承我们开发所需的大部分方法,几乎不需要自己动手编写sql语句了

 

通用mapper会默认自动将数据库表字段和实体类中的驼峰标识的属性进行转换,不需要像mabatis那样配置

 SpringBoot_02通用mapper

 

 

 

7.    运行结果(使用谷歌json数据显示插件显示)

 SpringBoot_02通用mapper