接口中涉及到@Mapper、@repository
相同点:两者都作用在dao层,使其生成代理对象bean,并交由spring容器管理
不同点:@repository需要搭配@MapperScan(“com.dao.mapper”)//在启动类配置mapper扫描地址 或者@Mapper配套使用才注入到service层。
@Mapper不需要配置扫描地址,通过xml里面的namespace里面的接口地址,生成的bean注入server层即可。(有的文章显示必须搭配@Repository,否则无法注入)
整个流程
1.导入依赖
mysql mysql-connector-java runtime org.springframework.boot spring-boot-starter-jdbc org.mybatis.spring.boot mybatis-spring-boot-starter 1.3.0
2.配置yml
spring:
datasource:
username: root
password: 123456
url: jdbc:mysql://localhost:3306/aa?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&userSSL=false
driver-class-name: com.mysql.cj.jdbc.Driver
mybatis:
#resultType时起别名
type-aliases-package: com.example.springbootmybatis.pojo
#Mapper与mapper.xml映射
mapper-locations: classpath:mybatis/mapper/*.xml
3.编写dao用户类
4.编写Mapper层(注意注解@Mapper、@Repository)
5.编写Mapper映射文件
select * from employee
6.测试即可
@SpringBootTest
class SpringbootMybatisApplicationTests {
@Autowired
EmployeeMapper employeeMapper;
@Test
void contextLoads() {
List all = employeeMapper.findAll();
for (Employee employee : all) {
System.out.println(employee);
}
}
}



