spring boot mybatis
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<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>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
- 在运行类上添加@MapperScan注解
- @MapperScan:
- 首先了解@Mapper 在接口上添加了@Mapper,在编译之后就会生成相应的接口实现类。 不过需要在每个接口上面进行配置,为了简化开发,就有了 @MapperScan。
@MapperScan
指定要变成实现类的接口所在的包,然后包下面的所有接口在编译之后都会生成相应的实现类。
@ComponentScan: 会自动扫描包路径下面的所有
@Controller、@Service、@Repository、@Component
的类,并把符合扫描规则的类装配到spring容器中。
@MapperScan和@ComponentScan
可以同时使用。
如果都是扫描的相同路径时,对于同一个接口,可能就会出现识别错误。比如
在springBoot项目的Application上面定义了
@MapperScan(basePackages = { "com" })
@SpringBootApplication
@SpringBootApplication包含了 -- @ComponentScan
- 在此项目下面有一个接口是com.xxInf,实现是com.xxImpl在实现类上面通过@Service加入spring容器中 我们在注入的时候接口时
@Autowired
private com.xxInf xx;
可能识别的不是xxImpl,而去mybatis里面通过反射找绑定,这样就会出现BindingException错误
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)
所以在设计项目结构的时候要把mapper放到一个合适的位置,通过设置MapperScan的路径basePackages 好避免这种冲突
server:
port: 80
# 配置数据源
spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/ssm-java1?useSSL=false
driver-class-name: com.mysql.cj.jdbc.Driver
username: root
password: 18044229
# 整合mybatis
mybatis:
# typeAliasesPackage: com.neuedu.entity
mapper-locations: classpath*:com/neuedu/boot/mapper/*.xml
- xml
<?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.osvue.app.user.mapper.UserMapper">
<select id="selectUser" resultType="map">
select * from book
</select>
</mapper>
- dao
import java.util.List;
import java.util.Map;
public interface UserMapper {
// com.osvue.app.user.mapper.UserMapper
List<Map<String,Object>> selectUser();
}
@RequestMapping("info")
@RestController
public class UserController {
@Autowired
UserMapper userMapper;
/**
*
* @return
*/
@RequestMapping("list")
public ResultBean getAllInfo() {
List<Map<String, Object>> userList = userMapper.selectUser();
return ResultBean.ok(userList);
}
}
@MapperScan(basePackages = {"com.osvue.app.*.mapper"})
@SpringBootApplication
public class AppApplication {
public static void main(String[] args) {
SpringApplication.run(AppApplication.class, args);
}
}