只需要在当前Service的实现类的操作方法内,使用DatasourceUtil.changeDb() 指那打那;
注意:使用多数据为了保证事务传播性,请@DSTransactional 注解。
*****
具体如下:
```
/**
* 切换到指定数据源
*/
@DSTransactional
@Override
public void add(ProjectGroupEntity projectGroup) {
// 切换到-指定数据源
DatasourceUtil.changeDb(DatasourceContext.me().getDbName());
// 校验参数
checkParam(projectGroup, false);
// 保存
this.save(projectGroup);
}
/**
* 同时操作-主数据源和从数据源
*/
@Override
public List<ProTableEntity> getProTableList(ProTableSearch proTableQuery) {
// 切换到-指定数据源
DatasourceUtil.changeDb(DatasourceContext.me().getDbName());
/**
* 先查询当前数据源-项目表List
*/
// 创建查询包装器
LambdaQueryWrapper<ProjectTableEntity> queryWrapper = new LambdaQueryWrapper<>();
// 设置条件
queryWrapper.eq(ProjectTableEntity::getDelFlag, CommonDelFlagEnum.NOT_DELETE.getCode());
// 设置排序
queryWrapper.orderByAsc(ProjectTableEntity::getSort);
// 查询
List<ProjectTableEntity> projectTableList = this.list(queryWrapper);
// 获取数据集标识的List
List<String> domainKeyList = projectTableList.stream().map(projectTable -> projectTable.getDomainKey()).collect(Collectors.toList());
/**
* 再查询主库数据源-项目基础表List
*/
DatasourceUtil.changeMasterDb();
// 获取参数
String domainName = proTableQuery.getDomainName();
String domainCode = proTableQuery.getDomainCode();
// 创建查询包装器
LambdaQueryWrapper<ProTableEntity> proTableQueryWrapper = new LambdaQueryWrapper<>();
// 设置条件
proTableQueryWrapper.eq(ProTableEntity::getDataFlag, CommonDataFlagEnum.NORMAL.getCode())
.eq(ProTableEntity::getDelFlag, CommonDelFlagEnum.NOT_DELETE.getCode());
// 判断
if (domainKeyList != null && domainKeyList.size() > 0) {
// 设置条件
proTableQueryWrapper.notIn(ProTableEntity::getDomainKey, domainKeyList);
}
// 设置排序
proTableQueryWrapper.orderByAsc(ProTableEntity::getSort);
// 条件查询
if (StrUtil.isNotBlank(domainName)) {
proTableQueryWrapper.like(ProTableEntity::getDomainName, domainName);
}
if (StrUtil.isNotBlank(domainCode)) {
proTableQueryWrapper.like(ProTableEntity::getDomainCode, domainCode);
}
// 返回
return proTableService.list(proTableQueryWrapper);
}
- Jump简介
- 技术架构
- 代码规范
- 规范导读
- JAVA规范
- 数据库表设计规范
- 集成项目
- JDK1.8-pom.xml
- JDK21-pom.xml
- 项目结构
- 业务模块-方法名称规范
- 跨域配置
- License授权配置
- 公共字段自动填充
- 全局异常处理器
- PageOffice配置
- Beetl模板引擎配置
- application.properties
- application-prod.yml
- banner.txt
- logback-spring.xml
- jump-core (核心组件)
- Maven依赖
- 通用枚举
- 公共数据状态 - 枚举
- 公共逻辑删除 - 枚举
- 公共操作编码类型 - 枚举
- 公共tree父节点 - 枚举
- 公共是或否 - 枚举
- 工具Util
- AopTargetUtil
- DownloadUtil
- GenerateNumUtil
- HttpServletUtil
- IpUtil
- JoinPointUtil
- MacUtil
- NetworkUtil
- ParamToUtil
- ResponseUtil
- TimeZoneDateUtil
- UaUtil
- 统一返回
- 结果对象
- 如何使用
- jump-cahche (缓存组件)
- Maven依赖
- Redis配置
- 缓存常量
- 工具Util
- RedisCacheUtil
- jump-idempotent (幕等组件)
- Maven依赖
- Context上下文
- 操作器
- 接口
- 如何实现
- AOP参数
- AOP使用方法
- jump-lock (分布式锁组件)
- Maven依赖
- 枚举
- AOP参数
- AOP使用方法
- 工具Util
- RedissonLockUtil
- Util使用方法
- jump-mybatis (mybatis组件)
- Maven依赖
- 基础Entity
- 枚举
- 查询类型 - 枚举
- 条件查询
- search
- service
- 分页结果集
- Mapper
- MyMapper
- 使用方法
- DDL操作
- DML操作
- 工具Util
- EntityUtil
- PageUtil
- TableUtil
- jump-dynamic-datasource (多数据源组件)
- Maven依赖
- Context上下文
- 操作器
- 接口
- 如何实现
- 工具Util
- DatasourceUtil
- 如何使用
- jump-satoken (satoken组件)
- Maven依赖
- Context上下文
- 操作器
- 接口
- 如何实现
- Satoken配置信息
- SatokenUser信息
- Redis缓存操作
- SatokenRedisCache
- SatokenUserRedisCache
- 放行白名单
- jump-oss (OSS组件)
- Maven依赖
- 工具Util
- OssFileUtil
- OssPlatformUtil
- 如何使用
- jump-xss (XSS组件)
- Maven依赖
- 白名单放行
- jump-email (邮件组件)
- Maven依赖
- Email客户端信息
- Email发送参数
- 工具Util
- jump-websocket (WebSocket组件)
- Maven依赖
- 消息对象
- 工具Util
- 如何使用
- jump-weixin (微信组件)
- Maven依赖
- jump-system (系统管理组件)
- Maven依赖
- AOP
- 系统操作日志AOP
- 系统数据日志AOP
- 系统操作权限AOP
- 字典转文本AOP
- Redis缓存操作
- SystemConfigRedisCache
- 工具Util
- LoginUserUtil
- SystemAreaUtil
- SystemHomeUtil
- SystemMenuUtil
- SystemOrgAdminUtil
- SystemOrgTypeUtil
- SystemRoleUtil
- SystemUserLoginAreaUtil
- SystemUserUtil
- jump-timer(定时器组件)
- Maven依赖
- 枚举
- Api接口
- 工具Util
- ActionClassUtil
- TimerTaskUtil
- 如何使用
- jump-ueditor (富文本组件)
- Maven依赖
- 如何使用
- 配置 ueditor.config.js
- 后端 application.properties
- 前端 vue3
- vue-codemirror (代码编译器)
- npm依赖
- PageOffice整合
- Maven依赖
- License授权配置
- 枚举
- 文件来源 - 枚举
- 预览文件类型 - 枚举
- 文件预览参数
- 下载文件
- 预览文件
- 工具Util