SpringBoot整合Mabatis

1、导入 MyBatis 所需要的依赖

<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.1</version>
</dependency>

2、配置数据库连接信息(延用不变,红色必要)  

spring:
  datasource:
    username: root
    password: 123456
    #?serverTimezone=UTC解决时区的报错
    url: jdbc:mysql://localhost:3306/springboot?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8
    driver-class-name: com.mysql.cj.jdbc.Driver
    type: com.alibaba.druid.pool.DruidDataSource

    #Spring Boot 默认是不注入这些属性值的,需要自己绑定
    #druid 数据源专有配置
    initialSize: 5
    minIdle: 5
    maxActive: 20
    maxWait: 60000
    timeBetweenEvictionRunsMillis: 60000
    minEvictableIdleTimeMillis: 300000
    validationQuery: SELECT 1 FROM DUAL
    testWhileIdle: true
    testOnBorrow: false
    testOnReturn: false
    poolPreparedStatements: true

    #配置监控统计拦截的filters,stat:监控统计、log4j:日志记录、wall:防御sql注入
    #如果允许时报错  java.lang.ClassNotFoundException: org.apache.log4j.Priority
    #则导入 log4j 依赖即可,Maven 地址:https://mvnrepository.com/artifact/log4j/log4j
    filters: stat,wall,log4j
    maxPoolPreparedStatementPerConnectionSize: 20
    useGlobalDataSourceStat: true
    connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500

3、创建mapper目录以及对应的 Mapper 接口


@Mapper //ibatis的注解,也可以在启动类上用mapperScan代替
@Repository
public interface TestCatMapper {

List<TestCat> getAllCat();

TestCat getCatById( Integer catId );

int addCat( TestCat testCat );

int updateCat( TestCat testCat );

int deleteCat( Integer catId );

}

4、对应的Mapper映射文件,用XML就不能在方法上直接写SQL了

<?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.hwl.swgger01.mapper.TestCatMapper">

    <select id="getAllCat" resultType="TestCat">
        select * from test_cat;
    </select>

    <select id="getCatById" resultType="TestCat" parameterType="int">
        select * from test_cat where cat_id = #{catId};
    </select>

    <insert id="addCat" parameterType="TestCat">
        insert into test_cat(cat_name,cat_age,cat_color) value(#{catName},#{catAge},#{catColor});
    </insert>

    <update id="updateCat" parameterType="TestCat">
        update test_cat set cat_name = #{catName} where cat_id = #{catId};
    </update>

    <delete id="delete" parameterType="int">
        delete from test_cat where cat_id = #{catId};
    </delete>

</mapper>

5、编写Controller、service进行测试!

@RestController
@RequestMapping("/cat2")
public class TestCatController2 {

    @Autowired
    TestCatService testCatService;

    @GetMapping("/getAllCat")
    public List<TestCat> getAllCat(){
        return testCatService.getAllCat();
    }

    @GetMapping("/getCatById/{catId}")
    public TestCat getCatById( @PathVariable("catId") Integer catId ){
        return testCatService.getCatById( catId );
    }

    @GetMapping("/add")
    public int addCat(){
        TestCat testCat = new TestCat("花花",2,"黑色");
        return testCatService.addCat( testCat );
    }

    @GetMapping("/update/{catId}")
    public int updateCat( @PathVariable("catId") Integer catId ){
        TestCat testCat = new TestCat("修改猫",catId);
        return testCatService.updateCat( testCat );
    }

    @GetMapping("/deleteCat/{catId}")
    public int deleteCat( @PathVariable("catId") Integer catId ){
        return  testCatService.deleteCat( catId );
    }
}

service:

@Service
public class TestCatService {

    @Autowired
    TestCatMapper testCatMapper;

    public List<TestCat> getAllCat(){
        return testCatMapper.getAllCat();
    }

    public TestCat getCatById( Integer catId ){
        return testCatMapper.getCatById( catId );
    }

    public int addCat( TestCat testCat ){
        return testCatMapper.addCat( testCat );
    }

    public int updateCat( TestCat testCat ){
        return testCatMapper.updateCat( testCat );
    }

    public int deleteCat( Integer catId ){
        return  testCatMapper.deleteCat( catId );
    }
}

6、启动项目访问进行测试!

 

 

 

 

posted @ 2021-10-04 18:54  四叶笔记  阅读(59)  评论(0编辑  收藏  举报