springboot整合mybatis步骤,与踩坑排错

一、前言

本文简单回顾一下springboot整合mybatis步骤,俗话说,刀放着不用会生锈,同理,学习也是如此,需要常常温故知新。

在整合过程中,也遇到了一些坑,具体看章节四,看你有没有遇到同样的问题

二、整合步骤

1.项目创建

创建一个普通的maven项目,或者你直接创建一个springboot项目也可以。

这里就不一一贴图了哈

2.依赖引入

要引入mybatis的核心支持,主要有mybatis-spring-boot-starterdruid-spring-boot-startermysql-connector-java,其他的根据自己需要引入。

<?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>org.example</groupId>
    <artifactId>demo-maven-create-boot</artifactId>
    <version>1.0-SNAPSHOT</version>

    <parent>
        <artifactId>spring-boot-starter-parent</artifactId>
        <groupId>org.springframework.boot</groupId>
        <version>2.3.7.RELEASE</version>
    </parent>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

<!--        mybatis支持-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.1.3</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.10</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>
</project>

3.配置

在项目的src/main/resources下创建application.properties文件,写入数据库的连接参数与myabtis的一些配置信息,(这一步你用yml格式文件也可以的)如下:

#数据库路径
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/demo?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&useSSL=false
#数据库驱动
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#数据库用户名
spring.datasource.username=root
#数据库用户密码
spring.datasource.password=*****
#数据库连接池
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
#mybatis类型别名配置,这里指定一个包,该包下的类的别名与类名一致
mybatis.type-aliases-package=org.lys.model
#指定mapper文件的位置
mybatis.mapper-locations=classpath:mybatis/mapper/*.xml

三、验证

1、创建一个简单的表来测试,如下:

2、自定义添加一些数据

3、实体类

@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
    private int id;

    private String name;
}

4、接口

@Mapper
public interface UserMapper {

    /**
     * 所有用户
     *
     * @return {@code List<User>}
     */
    List<User> getAllUsers();

    /**
     * 通过id查找用户
     *
     * @param id id
     * @return {@code User}
     */
    @Select("select * from user where id=#{id}")
    User getUserById(int id);

    /**
     * 插入用户
     *
     * @param user 用户
     * @return int
     */
    int insertUser(User user);

    /**
     * 批量查询
     *
     * @param ids id
     * @return {@code List<User>}
     */
    List<User> getAllUsersByIds(@Param("ids")Integer[] ids);

}

5、mapper文件

<?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="org.lys.dao.UserMapper">
    <insert id="insertUser" parameterType="User">
<!--        使用自带的UUID生成主键-->
        <selectKey resultType="Integer" keyProperty="id" order="BEFORE">
            select uuid();
        </selectKey>
        insert into user values (#{id}, #{name})
    </insert>

    <select id="getAllUsers" resultType="User">
        select * from user;
    </select>

    <select id="getAllUsersByIds" resultType="User">
        select * from user where id in
        <foreach collection="ids" open="(" close=")" item="id" separator=",">
            #{id}
        </foreach>
    </select>
</mapper>

6、测试

在需要引入的地方,直接注入相应的接口,即可直接调用。

@Autowired
private UserMapper userMapper;

四、踩坑排错

1.添加注解无法识别

解决:注意检查大小写,是**@Select**,而不是**@select**,这个注解是首字母是大写开头的哦。其他的注解在使用的时候也要注意哦!

2.IDEA社区版报各种颜色的错误

解决:上面的提示不影响程序运行,可忽略,就是看着不好看。可能是由于我使用的是IDEA社区版的原因,社区版不同于旗舰版,社区版少很多的支持。(推荐用IDEA旗舰版)

3.jar包打包后运行报错

我是这样打的jar包:

结果发现打包出来的包不可运行,咋一看上面打包出来的jar包只要几兆大小,说明我们项目需要用到的一些依赖包它没有给打包进来。

解决:由于我们创建的是maven项目,在pom.xml文件里添加一个maven插件,重新package即可,如下:

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
                <!--项目的启动类-->
                <mainClass>org.lys.DemoApplication</mainClass>
                <layout>ZIP</layout>
            </configuration>
            <executions>
                <execution>
                    <goals>
                        <goal>repackage</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

4.单元测试不可用

解决:经过检查,发现是自己没有添加单元测试的相关依赖,需要添加spring-boot-starter-test这个依赖,如下:

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

测试类这样写,记得添加@RunWith(SpringRunner.class)@SpringBootTest 这两个注解。

@RunWith(SpringRunner.class)
@SpringBootTest(classes = DemoApplication.class, webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
public class UserTest {
	
    @Test
    public void fun1(){
        //你的代码逻辑
    }
    
    @Test
    public void fun1(){
     	//你的代码逻辑   
    }
    //······
}

注意:在注解@springbootTest里面要指定启动类,否则加载不到上下文,会报下面的错误。

五、总结

操作一遍下来,整合步骤还是很容易的,因为Springboot为我们做了很多的自动化配置,你需要用到的技术,只需要引入响应的依赖,再加点基础参数接口。但是要注意一些细节,以免犯一些低级的错误。

本期分享到这,下期见!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员-小李

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值