1. 回顾 Spring 整合 Mybatis
Spring
整合 Mybatis
需要定义很多配置类
SpringConfig
配置类
导入 JdbcConfig
配置类
导入 MybatisConfig
配置类
@Configuration
@ComponentScan("com.itheima")
@PropertySource("classpath:jdbc.properties")
@Import({JdbcConfig.class,MyBatisConfig.class})
public class SpringConfig {
}
JdbcConfig
配置类
定义数据源(加载 properties 配置项:driver、url、username、password)
代码语言:javascript复制public class JdbcConfig {
@Value("${jdbc.driver}")
private String driver;
@Value("${jdbc.url}")
private String url;
@Value("${jdbc.username}")
private String userName;
@Value("${jdbc.password}")
private String password;
@Bean
public DataSource getDataSource(){
DruidDataSource ds = new DruidDataSource();
ds.setDriverClassName(driver);
ds.setUrl(url);
ds.setUsername(userName);
ds.setPassword(password);
return ds;
}
}
MybatisConfig
配置类
定义 SqlSessionFactoryBean
定义映射配置
代码语言:javascript复制@Bean
public MapperScannerConfigurer getMapperScannerConfigurer(){
MapperScannerConfigurer msc = new MapperScannerConfigurer();
msc.setBasePackage("com.itheima.dao");
return msc;
}
@Bean
public SqlSessionFactoryBean getSqlSessionFactoryBean(DataSource dataSource){
SqlSessionFactoryBean ssfb = new SqlSessionFactoryBean();
ssfb.setTypeAliasesPackage("com.itheima.domain");
ssfb.setDataSource(dataSource);
return ssfb;
}
2. SpringBoot 整合 mybatis
- 创建模块
定义实体类
代码语言:javascript复制public class Book {
private Integer id;
private String name;
private String type;
private String description;
public Book() {
}
public Book(Integer id, String name, String type, String description) {
this.id = id;
this.name = name;
this.type = type;
this.description = description;
}
@Override
public String toString() {
return "Book{"
"id=" id
", name='" name '''
", type='" type '''
", description='" description '''
'}';
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getType() {
return type;
}
public void setType(String type) {
this.type = type;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
}
定义 Dao 接口
代码语言:javascript复制public interface BookDao {
@Select("select * from tbl_book where id = #{id}")
public Book getById(Integer id);
}
定义测试类
代码语言:javascript复制@SpringBootTest
class Springboot03MybatisTestApplicationTests {
@Autowired
private BookDao bookDao;
@Test
void contextLoads() {
}
@Test
public void testMybatis() {
Book book = bookDao.getById(1);
System.out.println(book);
}
}
编写配置
在application.yml
中指定数据库
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/ssm?serverTimezone=UTC
username: root
password: 123456
测试
运行测试方法,我们会看到如下错误信息
错误信息显示在 Spring
容器中没有 BookDao
类型的 bean
。为什么会出现这种情况呢?
原因是 Mybatis
会扫描接口并创建接口的代码对象交给 Spring
管理,但是现在并没有告诉 Mybatis
哪个是 dao
接口。而我们要解决这个问题需要在BookDao
接口上使用 @Mapper
,BookDao
接口改进为
注意:
SpringBoot
版本低于 2.4.3(不含),Mysql 驱动版本大于 8.0 时,需要在 url 连接串中配置时区jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC
,或在 MySQL 数据库端配置时区解决此问题
使用 Druid 数据源
导入 Druid
依赖
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.16</version>
</dependency>
在 application.yml
配置文件配置
可以通过 spring.datasource.type
来配置使用什么数据源。配置文件内容可以改进为
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC
username: root
password: root
type: com.alibaba.druid.pool.DruidDataSource