继续上次,给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就被集成进来了。