使用Druid,以jdbc方式配置多数据源
文章目录
- 背景
- 示例代码(结合实际进行配置)
- 总结
背景
当使用Spring Boot项目并需要多数据源时,你可以使用Druid连接池来配置和管理多个数据源。以下是一个示例的配置和代码,以说明如何实现多数据源:
示例代码(结合实际进行配置)
-
首先,确保在pom.xml文件中添加Druid依赖:
<dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.2.6</version></dependency> -
创建两个数据源配置类,分别对应两个数据源(假设为dataSource1和dataSource2):
@Configurationpublic class DataSource1Config {@Bean@ConfigurationProperties("spring.datasource.druid.datasource1")public DataSource dataSource1() {return DruidDataSourceBuilder.create().build();}}@Configurationpublic class DataSource2Config {@Bean@ConfigurationProperties("spring.datasource.druid.datasource2")public DataSource dataSource2() {return DruidDataSourceBuilder.create().build();}}在上述代码中,使用@ConfigurationProperties注解将Druid配置属性绑定到数据源对象,并创建Druid数据源实例。
-
在application.properties或application.yml文件中配置数据源相关属性:
- application.properties示例:
spring.datasource.druid.datasource1.url=jdbc:mysql://localhost:3306/db1spring.datasource.druid.datasource1.username=username1spring.datasource.druid.datasource1.password=password1spring.datasource.druid.datasource1.driver-class-name=com.mysql.jdbc.Driverspring.datasource.druid.datasource2.url=jdbc:mysql://localhost:3306/db2spring.datasource.druid.datasource2.username=username2spring.datasource.druid.datasource2.password=password2spring.datasource.druid.datasource2.driver-class-name=com.mysql.jdbc.Driver- application.yml示例:
spring:datasource:druid:datasource1:url: jdbc:mysql://localhost:3306/db1username: username1password: password1driver-class-name: com.mysql.jdbc.Driverdatasource2:url: jdbc:mysql://localhost:3306/db2username: username2password: password2driver-class-name: com.mysql.jdbc.Driver在上述配置中,你可以根据实际情况修改URL、用户名和密码等数据源配置属性。
-
创建两个数据源的JdbcTemplate对象:
@Configurationpublic class JdbcTemplateConfig {@Beanpublic JdbcTemplate jdbcTemplate1(@Qualifier("dataSource1") DataSource dataSource1) {return new JdbcTemplate(dataSource1);}@Beanpublic JdbcTemplate jdbcTemplate2(@Qualifier("dataSource2") DataSource dataSource2) {return new JdbcTemplate(dataSource2);}}在上述代码中,使用@Qualifier注解指定要注入的数据源对象。
-
在需要使用数据源的地方,注入相应的JdbcTemplate并使用:
@Servicepublic class UserService {private final JdbcTemplate jdbcTemplate1;private final JdbcTemplate jdbcTemplate2;public UserService(@Qualifier("jdbcTemplate1") JdbcTemplate jdbcTemplate1,@Qualifier("jdbcTemplate2") JdbcTemplate jdbcTemplate2) {this.jdbcTemplate1 = jdbcTemplate1;this.jdbcTemplate2 = jdbcTemplate2;}public void getUserData() {String sql1 = "SELECT * FROM user1";List<Map<String, Object>> users1 = jdbcTemplate1.queryForList(sql1);String sql2 = "SELECT * FROM user2";List<Map<String, Object>> users2 = jdbcTemplate2.queryForList(sql2);// 处理数据...}}在上述代码中,通过构造函数注入两个JdbcTemplate对象,并使用它们执行相应的SQL查询操作。
总结
通过以上配置和代码,你可以在Spring Boot项目中实现多数据源的使用。每个数据源都有单独的Druid配置,并通过JdbcTemplate对象进行数据库操作。
如果大家遇到类似问题,欢迎评论区讨论,如有错误之处,敬请留言。
相关文章:
使用Druid,以jdbc方式配置多数据源
文章目录 背景示例代码(结合实际进行配置)总结 背景 当使用Spring Boot项目并需要多数据源时,你可以使用Druid连接池来配置和管理多个数据源。以下是一个示例的配置和代码,以说明如何实现多数据源: 示例代码…...
RabbitMQ基础(2)——发布订阅/fanout模式 topic模式 rabbitmq回调确认 延迟队列(死信)设计
目录 引出点对点(simple)Work queues 一对多发布订阅/fanout模式以登陆验证码为例pom文件导包application.yml文件rabbitmq的配置生产者生成验证码,发送给交换机消费者消费验证码 topic模式配置类增加配置生产者发送信息进行发送控制台查看 rabbitmq回调确认配置类验…...
2. VisionOS平台概述
Unity 对VisionOS的支持将 Unity 编辑器和运行时引擎的全部功能与RealityKit提供的渲染功能结合起来。Unity 的核心功能(包括脚本、物理、动画混合、AI、场景管理等)无需修改即可支持。这允许游戏和应用程序逻辑像任何其他 Unity 支持的平台一样在Vision…...
MySql存储过程详解
文章目录 存储过程1 介绍 基本语法创建:调用查看删除演示: 变量相关系统变量演示: 用户自定义变量局部变量 if语法参数介绍casewhilerepeatloop游标条件处理程序存储函数 存储过程 1 介绍 存储过程是事先经过编译并存储在数据库中的一段 SQL 语句的集合,调用存储过…...
CRM 系统实施风险分析
企业实施 CRM 系统将引起各个方面的巨大变化, CRM 系统实施项目中,有不 少成功的案例,也存在相当的风险,企业只有增强风险意识并积极防范,才有可能提高 CRM 实施成功的概率。 1.企业内部环境带来的风险 (…...
保持城市天际线(力扣)贪心 JAVA
给你一座由 n x n 个街区组成的城市,每个街区都包含一座立方体建筑。给你一个下标从 0 开始的 n x n 整数矩阵 grid ,其中 grid[r][c] 表示坐落于 r 行 c 列的建筑物的 高度 。 城市的 天际线 是从远处观察城市时,所有建筑物形成的外部轮廓。…...
电路综合原理与实践---T衰减与PI衰减的详细计算理论与设计仿真
电路综合原理与实践—T衰减与PI衰减的详细计算理论与设计仿真 最近要找工作在刷笔试题目,会刷到关于T衰减的理论计算问题,一直搞不明白怎么算的,搞明白之后给大家伙来分享一下。 基础理论可以参考:电阻衰减网络计算(P…...
1. 基于UDP的TFTP文件传输
1)tftp协议概述 简单文件传输协议,适用于在网络上进行文件传输的一套标准协议,使用UDP传输 特点: 是应用层协议 基于UDP协议实现 数据传输模式 octet:二进制模式(常用) mail:…...
django中使用bootstrap-datepicker时间插件
1、插件的下载 Bootstrap Datepicker是一款基 于Bootstrap框架的日期选择控件,可以方便地在Web应用中添加可交互的日期选择功能。Bootstrap Datepicker拥有丰富的选项和API,支持多种日期格式,可以自定义样式并支持各种语言。 Bootstrap Datepicker 依赖…...
《golang设计模式》第二部分·结构型模式-02-桥接模式(Bridge)
文章目录 1. 概念1.1 角色1.2 类图 2. 代码示例2.1 设计2.1 代码2.2 类图 1. 概念 客户端调用桥接接口实现原有功能和扩展功能的组合 1.1 角色 Implementor(实施者): 具体实施者的抽象,可以是一个接口。 Concrete Implementor&…...
【2023年11月第四版教材】《第4章-信息系统管理之管理要点(第四版新增章节)(第二部分)》
信息系统管理之管理要点(第四版新增章节)(第二部分) 2 管理要点2.1 数据管理能力成熟度评估模型DCMM详细表格简要表格 2.2 组织的管理成熟度2.3 能力模型2.4 智能运维能力框架2.5 安全保护等级 2 管理要点 2.1 数据管理能力成熟度…...
【算法——双指针】LeetCode 1089 复写零
千万不要被这道题标注着“简单”迷惑了,实际上需要注意的细节很多。 题目描述: 解题思路: 正序遍历,确定结果数组的最后一个元素所在的位置;知道最后一个元素的位置后倒序进行填充。 先找到最后一个需要复写的数 先…...
基于飞桨图学习框架实现的城市地点动态关系挖掘
李双利 飞桨开发者技术专家(PPDE),百度研究院商业智能实验室研究实习生,中国科学技术大学在读博士生。 主要进行时空数据挖掘和图深度学习的相关研究工作。曾获2021年百度研究院年度优秀实习生,有多篇基于飞桨完成的…...
3.1 Qt样式选择器
本期内容 3.1 样式选择器 3.1.1 Universal Selector (通用选择器) 3.1.2 Type Selector (类型选择器) 3.1.3 Property Selector (属性选择器) 3.1.4 Class Selector (类选择器) 3.1.5 ID Selector (ID选择器) 3.1.6 Descendant Selector (后裔选择器) 3.1.7 Chil…...
react钩子副作用理解
useEffect(() > { fetch(‘https://api.example.com/data’) .then(response > response.json()) .then(data > setData(data)); }, []); 怎么理解这个[] 在 React 中,useEffect 钩子用于处理副作用,比如数据获取、订阅、手动 DOM 操作等。useE…...
浅谈Spring与字节码生成技术
概要 今天来谈一谈我们熟知的Spring框架和字节码技术有什么联系。 Java程序员几乎都了解Spring。 它的IoC(依赖反转)和AOP(面向切面编程)功能非常强大、易用。而它背后的字节码生成技术(在运行时,根据需要…...
时序预测 | MATLAB实现基于BiLSTM双向长短期记忆神经网络的时间序列预测-递归预测未来(多指标评价)
时序预测 | MATLAB实现基于BiLSTM双向长短期记忆神经网络的时间序列预测-递归预测未来(多指标评价) 目录 时序预测 | MATLAB实现基于BiLSTM双向长短期记忆神经网络的时间序列预测-递归预测未来(多指标评价)预测结果基本介绍程序设计参考资料 预测结果 基本介绍 Matlab实现BiLST…...
Flink多流处理之coGroup(协同分组)
这篇文章主要介绍协同分组coGroup的使用,先讲解API代码模板,后面会结图解介绍coGroup是如何将流中数据进行分组的. 1 API介绍 数据源# 左流数据 ➜ ~ nc -lk 6666 101,Tom 102,小明 103,小黑 104,张强 105,Ken 106,GG小日子 107,小花 108,赵宣艺 109,明亮# 右流数据 ➜ ~ n…...
基于TICK的DevOps监控实战(Ubuntu20.04系统,Telegraf+InfluDB+Chronograf+Kapacitor)
1、TICK简介 TICK是InfluxData开发的开源高性能时序中台,集成了采集、存储、分析、可视化等能力,由Telegraf, InfluDB, Chronograf, Kapacitor等4个组件以一种灵活松散、但又紧密配合,互为补充的方式构成。TICK专注于DevOps监控、IoT监控、实…...
十九、docker学习-Dockerfile
Dockerfile 官网地址 https://docs.docker.com/engine/reference/builder/Dockerfile其实就是我们用来构建Docker镜像的源码,当然这不是所谓的编程源码,而是一些命令的集合,只要理解它的逻辑和语法格式,就可以很容易的编写Docke…...
MATLAB图像分割实战:从基础阈值到分水岭算法的进阶指南
1. 图像分割基础与MATLAB环境准备 图像分割是计算机视觉中的基础任务,简单来说就是把图像中我们感兴趣的部分"抠"出来。想象一下你在玩拼图游戏,图像分割就是帮你把拼图的每一块单独取出来的过程。在MATLAB里做图像分割,就像拥有了…...
Diff Checker:3个你没想到的文本对比高效技巧
Diff Checker:3个你没想到的文本对比高效技巧 【免费下载链接】diff-checker Desktop application to compare text differences between two files (Windows, Mac, Linux) 项目地址: https://gitcode.com/gh_mirrors/di/diff-checker 你是否曾经为了找出两份…...
COMSOL几何建模避坑指南:从二维草图到三维模型的完整参数化流程
COMSOL几何建模避坑指南:从二维草图到三维模型的完整参数化流程 几何建模是COMSOL仿真分析的基础环节,一个优秀的参数化模型不仅能提升工作效率,更能为后续的多物理场耦合分析奠定坚实基础。本文将系统梳理从二维草图到三维成型的完整工作流&…...
SensitivityMatcher:终极免费鼠标灵敏度跨游戏转换工具
SensitivityMatcher:终极免费鼠标灵敏度跨游戏转换工具 【免费下载链接】SensitivityMatcher Script that can be used to convert your mouse sensitivity between different 3D games. 项目地址: https://gitcode.com/gh_mirrors/se/SensitivityMatcher 还…...
5个简单步骤掌握Inter字体:从安装到高级应用的全方位指南
5个简单步骤掌握Inter字体:从安装到高级应用的全方位指南 【免费下载链接】inter The Inter font family 项目地址: https://gitcode.com/gh_mirrors/in/inter 在当今数字设计领域,选择合适的屏幕字体对于提升用户体验至关重要。Inter字体作为一款…...
探索三种Navicat试用期重置方案:轻松解锁Mac版数据库管理工具
探索三种Navicat试用期重置方案:轻松解锁Mac版数据库管理工具 【免费下载链接】navicat_reset_mac navicat mac版无限重置试用期脚本 Navicat Mac Version Unlimited Trial Reset Script 项目地址: https://gitcode.com/gh_mirrors/na/navicat_reset_mac 当N…...
终极Windows驱动清理指南:用Driver Store Explorer释放20GB磁盘空间
终极Windows驱动清理指南:用Driver Store Explorer释放20GB磁盘空间 【免费下载链接】DriverStoreExplorer Driver Store Explorer 项目地址: https://gitcode.com/gh_mirrors/dr/DriverStoreExplorer Driver Store Explorer(简称RAPR)…...
从Linux驱动本质到IgH EtherCAT完整流程:一篇彻底打通驱动、配置、库、硬件的硬核博客
在做EtherCAT运动控制、机械臂开发、机器人控制系统时,几乎所有人都会遇到一连串灵魂拷问:- Linux驱动到底是什么?- 为什么用户程序不能直接操作硬件?- ethercat.conf 绑定MAC、设置 generic 到底有什么用?- 用户程序…...
收藏!一文轻松看懂大模型核心术语,小白也能秒懂AI世界!
本文用公司角色比喻,通俗解释了LLM、Prompt、Agent、RAG、MCP等AI术语。LLM是“大脑”,负责思考与生成;Prompt是“指令”,指导大脑行动;Agent是“智能员工”,自主完成任务;Skill/Tool/RAG是“技…...
设计师的免费中文字体救星:思源宋体TTF的7重魔法
设计师的免费中文字体救星:思源宋体TTF的7重魔法 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还在为设计项目寻找既专业又免费的中文字体而头疼吗?…...
