SpringBoot快速入门
1.1SpringBoot 整合 Mybatis
回顾 Spring 整合 Mybatis
Spring 整合 Mybatis 需要定义很多配置类
- SpringConfig 配置类
- 导入 JdbcConfig 配置类
- 导入 MybatisConfig 配置类
@Configuration
@ComponentScan("com.demo")
@PropertySource("classpath:jdbc.properties")
@Import({JdbcConfig.class,MyBatisConfig.class})
public class SpringConfig {
}
- JdbcConfig 配置类
- 定义数据源(加载properties配置项:driver、url、username、password)
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
- 定义映射配置
@Bean
public MapperScannerConfigurer getMapperScannerConfigurer(){
MapperScannerConfigurer msc = new MapperScannerConfigurer();
msc.setBasePackage("com.demo.dao");
return msc;
}
@Bean
public SqlSessionFactoryBean getSqlSessionFactoryBean(DataSource dataSource){
SqlSessionFactoryBean ssfb = new SqlSessionFactoryBean();
ssfb.setTypeAliasesPackage("com.demo.domain");
ssfb.setDataSource(dataSource);
return ssfb;
}
1.2 SpringBoot 整合 mybatis
1.2.1 创建模块
- 创建新的SpringBoot模块,并配置相关信息
- 选择当前模块需要使用的技术集(MyBatis、MySQL)
1.2.2 定义实体类
在 com.demo.domain 包下定义实体类 Book ,内容如下
package com.demo.domain;
public class Book {
private Integer id;
private String name;
private String type;
private String description;
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;
}
public Integer getId() {
return id;
}
@Override
public String toString() {
return "Book{" +
"id=" + id +
", name='" + name + '\'' +
", type='" + type + '\'' +
", description='" + description + '\'' +
'}';
}
public void setId(Integer id) {
this.id = id;
}
}
1.2.3 定义Dao接口
在 com.demo.dao 包下定义 BookDao 接口,内容如下
public interface BookDao {
@Select("select * from db01 where id = #{id}")
public Book getBookById(Integer id);
}
1.2.4 定义测试类
在 test/java 下定义包 com.demo ,在该包下测试类,内容如下
@SpringBootTest
public class MybatisApplicationTests {
@Autowired
private BookDao bookDao;
@Test
void testGetById() {
Book book = bookDao.getBookById(1);
System.out.println(book);
}
}
1.2.5 编写配置
我们代码中并没有指定连接哪儿个数据库,用户名是什么,密码是什么。所以这部分需要在 SpringBoot 的配置文件中进行 配合
在 application.yml 配置文件中配置如下内容
spring:
datasource:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/ssm_db
username: root
password: root
1.2.6 运行测试方法
我们定义的测试类中它会提醒在Spring容器中没有BookDao类型的bean,原因是Mybatis 会扫描接口并创建接口的代码对象交给 Spring 管理,但是现在并没有告诉 Mybatis 哪个是 dao 接口。 而我们要解决这个问题需要在 BookDao 接口上使用 @Mapper , BookDao 接口改进为
@Mapper
public interface BookDao {
@Select("select * from db01 where id = #{id}")
public Book getBookById(Integer id);
}
注意:
- SpringBoot 版本低于2.4.3(不含),Mysql驱动版本大于8.0时,需要在url连接串中配置时区
- jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC ,或在MySQL数据库端配置时区解决此问题
1.2.7 使用Druid数据源
现在我们并没有指定数据源, SpringBoot 有默认的数据源,我们也可以指定使用 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