1.添加Maven依赖
pom.xml
<!-- 用于显示网页 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 用于对数据库操作,可使用其他方式如MyBatis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<!-- 数据库驱动,此案例使用MySQL数据库 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
2.编写配置文件
application.yml(或xml)
server:
port: 8080 #端口号
spring:
mysql1:
driver-class-name: com.mysql.jdbc.Driver #数据库驱动
jdbc-url: jdbc:mysql://127.0.0.1/edusys #数据库地址
username: root #数据库服务账号
password: 1234 #数据库服务密码
mysql2:
driver-class-name: com.mysql.jdbc.Driver
jdbc-url: jdbc:mysql://127.0.0.1/user
username: root
password: 1234
注:此处使用MySQL,连接两个不同的数据库,使用其他数据库服务,或者连接多个数据库同理
3.添加数据库配置类
DataSourceConfig
@Configuration
public class DataSourceConfig {
@Bean(name = "mysql1")
@ConfigurationProperties(prefix = "spring.mysql1")
public DataSource mysql1DataSource() {
return DataSourceBuilder.create().build();
}
@Bean(name = "mysqlJdbcTemplate1")
public JdbcTemplate mysql1Template(@Qualifier("mysql1") DataSource mysql1) {
return new JdbcTemplate(mysql1);
}
@Bean(name = "mysql2")
@ConfigurationProperties(prefix = "spring.mysql2")
public DataSource mysql2DataSource() {
return DataSourceBuilder.create().build();
}
@Bean(name = "mysqlJdbcTemplate2")
public JdbcTemplate mysql2Template(@Qualifier("mysql2") DataSource mysql2) {
return new JdbcTemplate(mysql2);
}
}
@ConfigurationProperties(prefix = “spring.mysql1”)
注入配置文件中以"spring.mysql1"为前缀的所有属性
@Qualifier(“mysql1”)
筛选命名为"mysql1"的Bean
4.添加控制层(为了在网页显示结果)
DemoController
@RestController
public class DemoController {
@Autowired
private JdbcTemplate mysqlJdbcTemplate1;
@Autowired
private JdbcTemplate mysqlJdbcTemplate2;
/**
* 获取第一个数据库中t_user表ID为1的记录
*/
@RequestMapping(value = "getM1User")
public String getM1User() {
String query = "select * from t_user where id = 1";
Map<String, Object> map = mysqlJdbcTemplate1.queryForMap(query);
return "Mysql1:" + map.toString();
}
/**
* 获取第二个数据库中t_user表ID为1的记录
*/
@RequestMapping(value = "getM2User")
public String getM2User() {
String query = "select * from t_user where id = 1";
Map<String, Object> map = mysqlJdbcTemplate2.queryForMap(query);
return "Mysql2:" + map.toString();
}
}
5.测试结果显示
输入URL:http://127.0.0.1:8080/getM1User
输入URL:http://127.0.0.1:8080/getM2User
完成从不同数据库中读取记录