玩springboot 2.1 踩坑记录如下:
1.找不到数据库驱动
最新的数据库驱动加载类:坑啊 mysql-connector-java-8.0.13.jar 最新的驱动
driver-class-name: com.mysql.cj.jdbc.Driver
2.找不到Mapper
情况1.忘了扫描mapper
@MapperScan("com.lx.demo02.mapper") //添加扫描mapper
@SpringBootApplication
public class Demo02Application {
public static void main(String[] args) {
SpringApplication.run(Demo02Application.class, args);
}
}
情况2.pom.xml 文件读取mapper.xml配置文件
添加代码:
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
具体整合代码如下:
pom.xml配置文件:
<?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>com.lx</groupId>
<artifactId>demo02</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>demo02</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.0.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>
</project>
application.yml配置文件:
#默认使用配置
spring:
profiles:
active: dev
mybatis:
typeAliasesPackage: com.lx.demo02.bean
mapperLocations: classpath:com/lx/demo02/mapper/*.xml
---
spring:
profiles: dev
datasource:
url: jdbc:mysql://localhost:3306/xyy
username: root
password: root
driver-class-name: com.mysql.cj.jdbc.Driver
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="com.lx.demo02.mapper.ItemMapper">
<select id="queryItemList" resultType="item">
select * from items
</select>
</mapper>
package com.lx.demo02.mapper;
import com.lx.demo02.bean.Item;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository("itemMapper")
public interface ItemMapper {
/**
* 查询 所有的 item
* @return
*/
public List<Item> queryItemList();
}
service 层:
@Service("itemService")
public class ItemService {
@Autowired
private ItemMapper itemMapper;
public List<Item> queryItems(){
return itemMapper.queryItemList();
}
}
controller 层代码:
@RestController
public class ItemController {
@Autowired
private ItemService itemService;
@RequestMapping("/items")
public List<Item> queryItems(){
return itemService.queryItems();
}
}