SpringBoot项目连接多个数据库

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
在这里插入图片描述
完成从不同数据库中读取记录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ww空ww

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值