一、整合MyBatis
- 导入坐标
<!-- Spring操作数据库 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.2.10.RELEASE</version>
</dependency>
<!-- spring整合mybatis的坐标,要版本对应 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.3.0</version>
</dependency>
- 创建
JdbcConfig
用于加载DataSource
public class JdbcConfig {
@Value("${jdbc.driverClassName}")
private String driverClassName;
@Value("${jdbc.url}")
private String url;
@Value("${jdbc.username}")
private String username;
@Value("${jdbc.password}")
private String password;
@Bean
public DataSource dataSource() {
DruidDataSource ds = new DruidDataSource();
ds.setDriverClassName(driverClassName);
ds.setUrl(url);
ds.setUsername(username);
ds.setPassword(password);
return ds;
}
}
- 创建
MybatisConfig.java
,用于替代mybatis-config.xml
的功能。
public class MybatisConfig {
@Bean
public SqlSessionFactoryBean sqlSessionFactoryBean(DataSource dataSource) {
SqlSessionFactoryBean ssfb = new SqlSessionFactoryBean();
//设置类型别名,替代<typeAliases>标签
ssfb.setTypeAliasesPackage("com.fn.domain");
//前面使用了Druid,引用datasource就行
ssfb.setDataSource(dataSource);
return ssfb;
}
/*
该方法替代了
<mappers>
<package name="com.fn.dao"/>
</mappers>
*/
@Bean
public MapperScannerConfigurer mapperScannerConfigurer() {
MapperScannerConfigurer msc = new MapperScannerConfigurer();
msc.setBasePackage("com.fn.dao");
return msc;
}
}
下面是xml文件和.java之间的转换关系:
- 使用
public class App2 {
public static void main(String[] args) {
//获取IoC容器对象
ApplicationContext ctx = new AnnotationConfigApplicationContext(SpringConfig.class);
//获取Bean
AccountService bean = ctx.getBean(AccountService.class);
//执行查询语句
Account byId = bean.findById(3);
System.out.println(byId);
}
}
二、整合JUnit
- 导入坐标
<!-- Junit -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13</version>
<scope>test</scope>
</dependency>
<!-- Spring整合JUnit -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.2.10.RELEASE</version>
</dependency>
- 创建相应的测试用例,写法如下
//设置专用的类运行器
@RunWith(SpringJUnit4ClassRunner.class)
//指定Spring配置文件
@ContextConfiguration(classes = SpringConfig.class)
public class AccountServiceTest {
//自动装配需要的bean对象
@Autowired
private AccountService accountService;
@Test
public void testFindById() {
System.out.println(accountService.findById(2));
}
@Test
public void testFindAll() {
System.out.println(accountService.findAll());
}
}