使用Spring Boot与达梦数据库(DM)进行多数据源配置及MyBatis Plus集成
使用Spring Boot与达梦数据库(DM)进行多数据源配置及MyBatis Plus集成
在现代企业级应用开发中,处理多个数据源是一个常见的需求。本文将详细介绍如何使用Spring Boot结合达梦数据库(DM),并通过MyBatis Plus来简化数据库操作,同时实现多数据源的动态切换。这不仅能够提高开发效率,还能增强系统的灵活性和可维护性。
引言
随着业务的发展,单一的数据源可能无法满足所有需求。例如,你可能需要从不同的数据库读取数据或写入数据到特定的数据库中。在这种情况下,采用多数据源配置可以提供更灵活的数据访问方式。此外,MyBatis Plus作为一个MyBatis的增强工具,提供了更多便捷的功能,如自动填充、逻辑删除等,极大地方便了开发者。
一、环境准备
在开始之前,请确保你的开发环境中已经安装并配置好了以下组件:
- JDK 1.8 或更高版本
- Maven 3.x
- Spring Boot 2.x
- 达梦数据库客户端及其JDBC驱动
二、项目依赖配置
首先,在pom.xml文件中添加必要的依赖项:
<dependencies><!-- Spring Boot JDBC Starter --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency><!-- DM JDBC Driver --><dependency><groupId>com.dameng</groupId><artifactId>Dm8JdbcDriver18</artifactId><version>8.1.1.49</version></dependency><!-- Dynamic Datasource Starter for MyBatis Plus --><dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-starter</artifactId><version>3.1.0</version></dependency><!-- MyBatis Plus --><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>最新版本</version></dependency>
</dependencies>
注意:请根据实际情况替换mybatis-plus-boot-starter的版本号为最新稳定版。
三、YAML配置详解
接下来是关键部分——配置文件application.yml,它定义了我们的多数据源信息以及MyBatis Plus的相关设置。
spring:datasource:dynamic:primary: db_realname # 默认使用的数据源名称datasource:db_realname:driver-class-name: dm.jdbc.driver.DmDrivertype: com.alibaba.druid.pool.DruidDataSourceurl: jdbc:dm://localhost:5237?schema=smartsitetest2username: TESTpassword: 123456789druid: # Druid连接池配置connection-properties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000initial-size: 5max-active: 50min-idle: 5max-wait: 80000pool-prepared-statements: truemax-pool-prepared-statement-per-connection-size: 20validation-query: SELECT 'x'test-on-borrow: truefilters: statdb_iot:driver-class-name: dm.jdbc.driver.DmDrivertype: com.alibaba.druid.pool.DruidDataSourceurl: jdbc:dm://localhost:5237?schema=smartsiteiottestusername: TESTpassword: 123456789druid: # Druid连接池配置connection-properties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000initial-size: 5max-active: 50min-idle: 5max-wait: 80000pool-prepared-statements: truemax-pool-prepared-statement-per-connection-size: 20validation-query: SELECT 'x'test-on-borrow: truefilters: stat# MyBatis Plus 配置
mybatis-plus:mapper-locations: classpath*:/mapper/*.xmltypeAliasesPackage: com.xxx.entityglobal-config:db-config:id-type: AUTOfield-strategy: NOT_NULLcolumn-underline: truelogic-delete-value: -1logic-not-delete-value: 0banner: falseconfiguration:map-underscore-to-camel-case: truecache-enabled: falsecall-setters-on-nulls: truejdbc-type-for-null: 'null'log-impl: org.apache.ibatis.logging.stdout.StdOutImpllogging:level:root: INFOorg.springframework.web.servlet.DispatcherServlet: DEBUGfile:path: logs
四、注意事项
- 性能优化:对于生产环境,建议调整Druid连接池参数以适应实际负载。
- 安全性:避免直接在配置文件中硬编码数据库用户名和密码,考虑使用加密存储或其他安全措施。
- 异常处理:在代码中加入适当的异常处理机制,确保系统健壮性。
五、总结
通过本文的介绍,我们了解了如何在Spring Boot项目中配置多数据源,并且利用MyBatis Plus简化数据库操作。这种架构不仅提高了代码的可维护性和扩展性,也为后续功能的迭代打下了良好的基础。希望这篇文章能帮助你在未来的项目中更好地管理和利用数据库资源。如果你有任何问题或建议,欢迎留言讨论!
相关文章:
使用Spring Boot与达梦数据库(DM)进行多数据源配置及MyBatis Plus集成
使用Spring Boot与达梦数据库(DM)进行多数据源配置及MyBatis Plus集成 在现代企业级应用开发中,处理多个数据源是一个常见的需求。本文将详细介绍如何使用Spring Boot结合达梦数据库(DM),并通过MyBatis Plus来简化数据库操作&…...
leetcode28 找出字符串第一个匹配值的下标 KMP算法
KMP 算法——快速的从主串中找到模式串 当出现字符串不匹配时,可以知道一部分之前已经匹配的文本内容,可以利用这些信息避免从头再去做匹配了。 KMP 算法 比较指针不回溯,仅仅是后移模式串。 每次不匹配的时候,找之前已匹配部分…...
【Bug】natten:安装报错(临近注意力机制的高效cuda内核实现)
正常安装natten报错 pip install natten 报错 可以尝试使用以下网站进行安装 https://shi-labs.com/natten/ 可以根据自己的cuda与pytorch版本进行安装 之间复制命令即可,不需要进行任何修改...
AI 实战2 - face -detect
人脸检测 环境安装源设置conda 环境安装依赖库 概述数据集wider_face转yolo环境依赖标注信息格式转换图片处理生成 train.txt 文件 数据集展示数据集加载和处理 参考文章 环境 安装源设置 conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/f…...
Spring Boot 项目开发流程全解析
目录 引言 一、开发环境准备 二、创建项目 三、项目结构 四、开发业务逻辑 1.创建实体类: 2.创建数据访问层(DAO): 3.创建服务层(Service): 4.创建控制器层(Controller&…...
从Java到MySQL8源码:深入解析PreparedStatement参数绑定与执行机制
引言 在数据库开发中,PreparedStatement(预处理语句)是防止SQL注入、提升性能的重要工具。它通过分离SQL结构与参数值,不仅增强了安全性,还能利用预编译优化执行效率。本文将从Java JDBC驱动和MySQL 8源码的双重视角&…...
mysql的主从同步
1、异步复制:这是MySQL默认的复制模式。在这种模式下,主库在执行完客户端提交的事务后会立即将结果返回给客户端,并不关心从库是否已经接收并处理。这种模式的优点是实现简单,但缺点是如果主库崩溃,已经提交的事务可能…...
工程化与框架系列(10)--微前端架构
微前端架构 🏗️ 微前端是一种将前端应用分解成更小、更易管理的独立部分的架构模式。本文将详细介绍微前端的核心概念、实现方案和最佳实践。 微前端概述 🌟 💡 小知识:微前端的核心理念是将前端应用分解成一系列独立部署、松耦…...
【3天快速入门WPF】11-附加属性
目录 1. 步骤1:定义附加属性2. 示例代码3. 步骤2:在XAML中使用附加属性3.1. 示例代码4. 步骤3:扩展使用场景4.1. 示例代码5. 总结上一篇讲到了依赖属性,本篇主要想说一下附加属性。 在WPF中,附加属性(Attached Property)是一种特殊的依赖属性,允许你在不属于某个类的控…...
MySQL并发知识(面试高频)
mysql并发事务解决 不同隔离级别下,mysql解决并发事务的方式不同。主要由锁机制和MVCC(多版本并发控制)机制来解决并发事务问题。 1. mysql中的锁有哪些? 表级锁: 场景:表级锁适用于需要对整个表进行操作的情况,例如…...
现存脑容知识库
Redis import queue import threading import asyncio 异步:在一个线程内,等待的时候可以切换到其他任务。 多线程:每个线程独立运行,同时处理多个任务。 回调函数 网络请求(JavaScript)在浏览器中&a…...
Mysql-如何理解事务?
一、事务是什么东西 有些场景中,某个操作需要多个sql配合完成: 例如: 李四这个月剩下的前不够交房租了,找张三借1000元急用: (1)给张三的账户余额 减去1000元 updata 账户表 set money money -…...
dify绑定飞书多维表格
dify 绑定飞书和绑定 notion 有差不多的过程,都需要套一层应用的壳子,而没有直接可以访问飞书文档的 API。本文记录如何在dify工具中使用新增多条记录工具。 创建飞书应用 在飞书开放平台创建一个应用,个人用户创建企业自建应用。 自定义应…...
QT播放视频保持视频宽高比消除黑边
QT播放视频保持视频宽高比消除黑边 1、问题 在播放视频的时候,由于框架的大小发生变化,导致视频出现黑边很不好看。 因此需要像一种方法消除黑边 2、处理 1、读取视频的宽高比 2、设置视频的Widget的大小固定,Widget的宽高比和视频宽高比…...
1. IO的基础知识
1.1 流 Java程序通过流执行IO。流是一种抽象,它要么生成信息,要么使用信息。流通过java的IO系统链接到物理设备。所有流的行为方式都是相同的,尽管它们链接的物理设备是不同的。 1.2 字节流和字符流 Java定义了两种类型的流 : 字节流和字符流…...
科普:ROC AUC与PR AUC
在评价二分类模型性能时,有许多评价指标,其中,有一对是用面积AUC(Area Under the Curve)做评价的:ROC AUC与PR AUC 本文我们对ROC AUC与PR AUC进行多维度对比分析: 一、定义与核心原理 维度RO…...
Vue3父组件访问子组件方法与属性完全指南
在Vue3的组件化开发中,父子组件间的通信是核心功能之一。本文将详细介绍五种父组件访问子组件属性/方法的实现方案,包含最新的<script setup>语法糖实践。(综合1579) 一、ref defineExpose(推荐方案࿰…...
AI时代保护自己的隐私
人工智能最重要的就是数据,让我们面对现实,大多数人都不知道他们每天要向人工智能提供多少数据。你输入的每条聊天记录,你发出的每条语音命令,人工智能生成的每张图片、电子邮件和文本。我建设了一个网站(haptool.com),…...
Android APK组成编译打包流程详解
Android APK(Android Package)是 Android 应用的安装包文件,其组成和打包流程涉及多个步骤和文件结构。以下是详细的说明: 一、APK 的组成 APK 是一个 ZIP 格式的压缩包,包含应用运行所需的所有文件。解压后主要包含以…...
TCP长连接与短连接
TCP长连接与短连接 TCP(传输控制协议)中的长连接和短连接是两种不同的连接管理方式,各有优缺点: 短连接 短连接是指客户端与服务器完成一次数据交换后就断开连接。下次需要通信时,再重新建立连接。 特点࿱…...
记录复现多模态大模型论文OPERA的一周工作
一、 什么是 AI Skills:从工具级到框架级的演化 AI Skills(AI 技能) 的概念最早在 Claude Code 等前沿 Agent 实践中被强化。最初,Skills 被视为“工具级”的增强,如简单的文件读写或终端操作,方便用户快速…...
IDEA查看Maven依赖源码全攻略:从下载失败到源码解析一条龙
IDEA高效查看Maven依赖源码实战指南 在Java开发中,阅读第三方库的源码是提升编码能力的必经之路。但当你满怀期待地点击IDEA中的"Download Sources"按钮时,却可能遭遇各种意外——进度条卡住、报错提示、或者下载完成后依然只能看到.class文件…...
告别ArcMap:在ArcGIS Pro 3.0时代,如何正确获取并配置PostgreSQL的ST_Geometry.dll
深度解析:ArcGIS Pro 3.0与PostgreSQL空间数据库的ST_Geometry.dll配置实战 当我们将空间数据库从传统ArcMap迁移到ArcGIS Pro 3.0时,ST_Geometry.dll这个看似微小的动态链接库文件往往成为最容易被忽视却又最关键的技术瓶颈。许多资深GIS工程师在深夜调…...
为什么选择Clef Handbook:15个创新政策彻底改变传统雇佣关系
为什么选择Clef Handbook:15个创新政策彻底改变传统雇佣关系 【免费下载链接】handbook An employee handbook built for inclusion 项目地址: https://gitcode.com/gh_mirrors/handbook6/handbook Clef Handbook是一份为包容性而构建的员工手册(…...
技术深度解析:如何通过Turbo Boost动态控制优化Mac系统性能与散热管理
技术深度解析:如何通过Turbo Boost动态控制优化Mac系统性能与散热管理 【免费下载链接】Turbo-Boost-Switcher Turbo Boost disabler / enable app for Mac OS X 项目地址: https://gitcode.com/gh_mirrors/tu/Turbo-Boost-Switcher Turbo Boost Switcher是一…...
深度测评|2026AI短剧出海服务商
2026 年短剧出海进入全球化传播阶段,声画同步与多语种适配成为短剧出海的基础核心能力,更是保障海外受众观剧体验的关键要素。相较于国内市场,海外受众来自不同的语言区域,对多语种配音的自然度、口型同步的精准度、台词翻译的适配…...
Z-Image-Turbo-rinaiqiao-huiyewunv保姆级教程:如何将本地Turbo模型接入Discord Bot提供绘图服务
Z-Image-Turbo-rinaiqiao-huiyewunv保姆级教程:如何将本地Turbo模型接入Discord Bot提供绘图服务 你是不是也想过,让自己的Discord服务器里有一个专属的“画师”?当群友描述一个二次元角色时,这个Bot就能立刻画出来,而…...
dify可以干什么
Dify 是一个开源的大模型(LLM)应用开发平台,旨在帮助你快速构建、管理和部署生成式 AI 应用,而无需从零开始写代码。简单来说,你可以把它理解为一个可视化的 AI 应用“工作台”,通过拖拉拽的方式࿰…...
三极管相关电路
注意:1、判断三极管工作在什么区,最严谨的判断是根据发射结和集电极的正偏以及反偏来判断的。后面为了工程方便分析才没有用严谨的判断方案。要求必须背下三极管和二极管的伏安特性曲线。 三极管简单介绍:三极管分为n管和p管,n管为npn,p管为pnp。三极管有三个引脚,是基极…...
XP.css终极指南:如何用CSS完美复刻Windows经典界面
XP.css终极指南:如何用CSS完美复刻Windows经典界面 【免费下载链接】XP.css A CSS framework for building faithful recreations of operating system GUIs. 项目地址: https://gitcode.com/gh_mirrors/xp/XP.css 你是否怀念Windows XP和Windows 98那经典的…...
