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:
  1. 首先了解@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);
    }

}