【springboot系列】springboot集成mybatis

本文详细介绍了如何在SpringBoot项目中集成Mybatis,包括添加Mybatis依赖、配置Druid连接池、创建数据库表、定义DAO接口、Service及Controller,以及测试数据库连接和事务管理。通过示例代码展示了事务在并发情况下的效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

springboot集成mybatis

1、mybatis依赖:

官方文档
添加以下依赖:

<!--4、mybatis依赖添加-->
    <dependency>
      <groupId>org.mybatis.spring.boot</groupId>
      <artifactId>mybatis-spring-boot-starter</artifactId>
      <version>1.3.2</version>
    </dependency>

配置项如下:
在这里插入图片描述

#mybatis
# application.properties
mybatis.type-aliases-package=xyz.haibofaith.miaosha.model
#下划线转驼峰
mybatis.configuration.map-underscore-to-camel-case=true
mybatis.configuration.default-fetch-size=100
mybatis.configuration.default-statement-timeout=3000
#将接口与xml放在同一个路径下
mybatis.mapper-locations=classpath:com/haibofaith/miaosha/dao/*.xml

2、druid连接池和数据源

添加如下依赖文件:(mysql+druid)

<!--mysql-->
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <scope>runtime</scope>
    </dependency>
    <!-- druid -->
    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>druid-spring-boot-starter</artifactId>
      <version>1.1.10</version>
    </dependency>

application.properties配置文件添加如下:

# druid
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/haibodb?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&useSSL=false
spring.datasource.username=root
spring.datasource.password=haibo1118
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.filters=stat
spring.datasource.maxActive=2
spring.datasource.initialSize=1
spring.datasource.maxWait=60000
spring.datasource.minIdle=1
spring.datasource.timeBetweenEvictionRunsMillis=60000
spring.datasource.minEvictableIdleTimeMillis=300000
spring.datasource.validationQuery=select 'x'
spring.datasource.testWhileIdle=true
spring.datasource.testOnBorrow=false
spring.datasource.testOnReturn=false
spring.datasource.poolPreparedStatements=true
spring.datasource.maxOpenPreparedStatements=20

在这里插入图片描述

3、测试数据库连接

新建一张数据库表:

CREATE TABLE `haibodb`.`user_info` (
	`id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'id',
	`name` varchar(20) DEFAULT NULL COMMENT '姓名',
	PRIMARY KEY (`id`)
) ENGINE=`InnoDB` AUTO_INCREMENT=1 DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci ROW_FORMAT=COMPACT COMMENT='' CHECKSUM=0 DELAY_KEY_WRITE=0;

插入一条数据: 1,haibo

创建一个dao接口:

package xyz.haibofaith.miaosha.dao;

import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import xyz.haibofaith.miaosha.model.UserInfo;

@Mapper
public interface UserInfoDao {
    @Select("select * from user_info where id = #{id}")
    public UserInfo getById(@Param("id") int id);
}

创建一个Service类:

package xyz.haibofaith.miaosha.service;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import xyz.haibofaith.miaosha.dao.UserInfoDao;
import xyz.haibofaith.miaosha.model.UserInfo;

/**
 * @author:haibo.xiong
 * @date:2019/5/5
 * @description:
 */
@Service
public class UserInfoSerivice {
    @Autowired
    UserInfoDao userInfoDao;
    public UserInfo getById(int id){
        return userInfoDao.getById(id);
    }
}

创建一个Controller接口:

@Autowired
    UserInfoSerivice userInfoSerivice;

    @RequestMapping("/dbGet")
    @ResponseBody
    public Result<UserInfo> dbGet(){
        UserInfo userInfo = userInfoSerivice.getById(1);
        return Result.success(userInfo);
    }

项目结构如下

在这里插入图片描述

访问以下路径测试结果

http://localhost:8096/demo/dbGet
在这里插入图片描述

4、事务

dao写一个insert方法:

package xyz.haibofaith.miaosha.dao;

import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import xyz.haibofaith.miaosha.model.UserInfo;

@Mapper
public interface UserInfoDao {
    @Select("select * from user_info where id = #{id}")
    public UserInfo getById(@Param("id") int id);
    @Insert("insert into user_info(id,name) values(#{id},#{name})")
    void insert(UserInfo userInfo);
}

service中新增重复Id的代码块:

package xyz.haibofaith.miaosha.service;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import xyz.haibofaith.miaosha.dao.UserInfoDao;
import xyz.haibofaith.miaosha.model.UserInfo;

/**
 * @author:haibo.xiong
 * @date:2019/5/5
 * @description:
 */
@Service
public class UserInfoSerivice {
    @Autowired
    UserInfoDao userInfoDao;
    public UserInfo getById(int id){
        return userInfoDao.getById(id);
    }
    @Transactional
    public boolean tx() {
        UserInfo userInfo1 = new UserInfo();
        userInfo1.setId(2);
        userInfo1.setName("hehe");
        userInfoDao.insert(userInfo1);
        UserInfo userInfo2 = new UserInfo();
        userInfo2.setId(1);
        userInfo2.setName("shiwu");
        userInfoDao.insert(userInfo2);
        return true;
    }
}

controller调用:

@RequestMapping("/dbTx")
    @ResponseBody
    public Result<Boolean> dbTx(){
        boolean b = userInfoSerivice.tx();
        return Result.success(b);
    }

访问以下路径测试:
http://localhost:8096/demo/dbTx
在这里插入图片描述
查看数据库发现,两条数据均未插入。假如去掉注解Transactional,则第一条会被插入。

4、源码自取

github源码路径

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值