记录搭建springboot工程(二):加入mybatis

继续上次,给springboot加入mybatis部分
首先添加pom.xml的依赖:

<!-- mybatis依赖 -->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.2.0</version>
        </dependency>

        <!-- mysql jdbc -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.35</version>
        </dependency>

这里我不是很清楚版本兼容性的问题,记得很久很久以前好像遇到过版本不兼容的问题,不过具体情况也记不清了。

添加mybatis generator插件依赖:

<!-- mybatis generator 自动生成代码插件 -->

            <plugin>

                <groupId>org.mybatis.generator</groupId>

                <artifactId>mybatis-generator-maven-plugin</artifactId>

                <version>1.3.2</version>

                <configuration>

                    <!-- 自动生成mapper的配置文件的存放路径 -->
                    <configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile>
					<!-- 重新生成的话,直接覆盖原有的 -->
                    <overwrite>true</overwrite>

                    <verbose>true</verbose>

                </configuration>
                <!-- 我在插件里把mysql的jdbc依赖又重新配置了一遍,最开始生成不成功,查了一下说是要单独配置一个jdbc,这么做了之后就好用了,不过我好像也有见过不这样配也能自动生成的,目前原因不明。。 -->
                <dependencies>
                    <dependency>
                        <groupId>mysql</groupId>
                        <artifactId>mysql-connector-java</artifactId>
                        <version>5.1.35</version>
                    </dependency>
                </dependencies>
            </plugin>

这里使用mybatis接口编程,接口用generator插件自动生成,这样省去了一部分创建model和mapper,sql语句的时间。
在配置文件application-dev.properties添加数据库相关配置:

#配置数据源
spring.datasource.url=jdbc:mysql://localhost:3306/spring?useUnicode=true&characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

mybatis.type-aliases-package=com.wmx.firstspringproject.model
mybatis.mapper-locations=classpath:mapper/*Mapper.xml

在resources下新建generator文件夹,下面新建generatorConfig.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
        PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
	<!-- 把配置文件引入,直接使用里面的属性值 -->
    <properties resource="application-dev.properties"/>

    <context id="ssm" targetRuntime="MyBatis3">
        <commentGenerator>
            <property name="suppressDate" value="true" />
        <property name="suppressAllComments" value="true" />
    </commentGenerator>
    <!-- 配置数据源 -->
        <jdbcConnection driverClass="${spring.datasource.driver-class-name}"
                        connectionURL="${spring.datasource.url}" userId="${spring.datasource.username}" password="${spring.datasource.password}">
        </jdbcConnection>

        <javaTypeResolver>
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>
		<!-- 配置表实体类存放的路径 -->
        <javaModelGenerator targetPackage="com.wmx.firstspringproject.model" targetProject="src/main/java">
            <property name="constructorBased" value="false" />
            <property name="enableSubPackages" value="false" />
            <property name="trimStrings" value="true" />
        </javaModelGenerator>
		<!-- 配置mapper.xml的存放路径 -->
        <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources">
            <property name="enableSubPackages" value="false" />
        </sqlMapGenerator>
		<!-- 配置查询接口的存放路径 -->
        <javaClientGenerator type="XMLMAPPER" targetPackage="com.wmx.firstspringproject.mapper"
                             targetProject="src/main/java">
            <property name="enableSubPackages" value="false" />
        </javaClientGenerator>

		<!-- 配置需要生成mapper的表,后面的几个带Example的属性我全都设置成了false,不然实体类里会多生成一个example类,mapper文件也是看起来乱七八糟的,目前我还没太明白这example类是做什么的 -->
        <table tableName="account" enableCountByExample="false"
               enableUpdateByExample="false"
               enableDeleteByExample="false"
               enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>
    </context>
</generatorConfiguration>

然后运行插件,就会根据你配置的表,自动生成mapper需要的相关文件了:
在这里插入图片描述

生成后大概是这个样子:
在这里插入图片描述
具体的代码我就不贴了,它这个自动生成的查询,好像基本都是针对单表的增删改查,如果有多表关联的查询,基本还是要靠自己去写的,或者是我的配置文件上哪里有问题,因为自己也是初学者,也有很多不懂的地方。

创建service,这里只贴接口的实现类了,接口就不贴了:

@Service
public class AccountServiceImpl implements AccountService {

    @Autowired
    public AccountMapper mapper;

    @Override
    public Account getById(int id) {
        return mapper.selectByPrimaryKey(id);
    }
}

controller里添加方法:

	@Autowired
    public AccountService service;


    @RequestMapping(value="/getById",method = RequestMethod.GET)
    @ResponseBody
    public Account getAccountById(@RequestParam("id") int id){
        return service.getById(id);
    }

在启动类MyFirstSpringBootApplication上添加如下注解(非常重要,最开始因为自己没有添加这个,service层的mapper一直注入不进来):

@MapperScan("com.wmx.firstspringproject.mapper")

启动工程,在浏览器地址栏输入:

http://localhost:8080/first/getById?id=1

表和数据都是我很久很久以前不知道看什么的时候建的,测试结果如下:
在这里插入图片描述

这样,一个非常基础的mybatis就被集成进来了。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值