首先,简单的介绍下什么是JEECG。JEECG(J2EECode Generation)是一款基于代码生成器的免费开源的快速开发平台,使用JEECG可以简单快速地开发出企业级的Web应用系统。JEECG提倡简单功能由代码生成器直接生成,复杂业务采用表单自定义,业务流程使用工作流来实现、扩展出任务接口,由开发者编写特殊业务逻辑。

下面我们重点讲解下JEECG3.5GA版本多数据源的使用。在使用多数据源之前我们有必要了解什么是多数据源?为什么我们需要使用多数据源呢?多数据源是指同一个系统中处理的数据来自不同的数据源。比如我们在用ETL做数据同步、清洗和整合的时候经常要配置源库、整合库、清洗库、目标库等,如此多的数据源,我们需要采用灵活的机制配置,保证数据源间的自由切换。JEECG3.5提供了多数据源的功能,JEECG多数据源的设计直接利用了Springjdbc连接,跟Hibernate、Mybatis等持久化框架无关,就跟我们采用最原始的JDBC连接一样,简单方便。JEECG数据库中t_s_data_source表用来存放动态的数据源,系统在启动时通过org.jeecgframework.web.system.listener.InitListener把t_s_data_source表中的所有动态数据源信息配置到静态的Map中,其中t_s_data_source.db_key字段作为Map的key,以t_s_data_source的实体类作为value。

下面简单介绍下如何在JEECG3.5GA中使用多数据源。

1.配置多数据源管理菜单并分配权限。

(1) 配置多数据源管理菜单。

找到DynamicDataSourceController数据源配置控制类,可以方便的看出数据源配置的url是dynamicDataSourceController.do?dbSource。

进入“系统管理”à“菜单管理”,单击“菜单录入”,录入菜单信息如下:

其中菜单地址为:dynamicDataSourceController.do?dbSource,单击“确定”按钮,保存菜单信息。

(2)为角色分配菜单权限。

进入“系统管理”à“角色管理”,单击“角色列表”下的【权限设置】,加载“菜单列表”,勾选“多数据源管理”前面的复选框,单击“菜单列表”旁边的保存图标进行保存角色菜单权限。

(3)退出系统重新登录。可以看到“系统管理”中增加“多数据源管理”菜单。

2、录入数据源信息。

(1)进入“系统管理”à“多数据源管理”,进入如下页面。


(2)单击“录入”,录入数据源信息,并保存。

说明:每次新增或者编辑数据源的时候,系统都会动态刷新缓存中的数据源信息。

1. 动态使用多数据源。

具体各个方法使用请查看org.jeecgframework.core.util.DynamicDBUtil工具类。重点关注下面三个方法:

public static List<Map<String, Object>> findList(final String dbKey, String sql, Object... param);

public static Object findOne(finalString dbKey, String sql, Object... param);

public static int update(finalString dbKey, String sql, Object... param);

创建Service实现类,同时在页面必须上传要调用数据源的dbKey.

/**

* 动态数据源测试

@param dbKey 数据源KEY

@return

*/

public List<Map<String,Object>> queryDynamicDB(String dbKey){

final String sql = "select * from tbl_sys_user";

List<Map<String,Object>> userList = DynamicDBUtil.findList(dbKey, sql, null);

return userList;

}

以上就是对JEECG3.5GA多数据源使用的简单分析,通过以上分析我们知道JEECG把数据源存放在数据库里,方便灵活的管理和维护数据源,同时采用SpringJdbc进行多数据源的处理,简单直接,同时效率较高。

浅谈JEECG多数据源的使用的更多相关文章

  1. 浅谈Android编码规范及命名规范

    前言: 目前工作负责两个医疗APP项目的开发,同时使用LeanCloud进行云端配合开发,完全单挑. 现大框架已经完成,正在进行细节模块上的开发 抽空总结一下Android项目的开发规范:1.编码规范 ...

  2. 浅谈RecyclerView(完美替代ListView,GridView)

    Android RecyclerView 是Android5.0推出来的,导入support-v7包即可使用. 个人体验来说,RecyclerView绝对是一款功能强大的控件. 首先总结下Recycl ...

  3. 安卓开发_浅谈ListView(SimpleAdapter数组适配器)

    安卓开发_浅谈ListView(ArrayAdapter数组适配器) 学习使用ListView组件和SimapleAdapter适配器实现一个带图标的ListView列表 总共3部分 一.MainAc ...

  4. 【架构】浅谈web网站架构演变过程

    浅谈web网站架构演变过程   前言 我们以javaweb为例,来搭建一个简单的电商系统,看看这个系统可以如何一步步演变.   该系统具备的功能:   用户模块:用户注册和管理 商品模块:商品展示和管 ...

  5. Hibernate更新部分字段浅谈

    update语句是在Hibernate的Configuration的时候生成的,不能动态改变.为什么update的时候所有的属性都一起update,而不是只更新改变字段,其实这是一个比较值得探讨的问题 ...

  6. 浅谈Vue不同场景下组件间的数据交流

    浅谈Vue不同场景下组件间的数据“交流”   Vue的官方文档可以说是很详细了.在我看来,它和react等其他框架文档一样,讲述的方式的更多的是“方法论”,而不是“场景论”,这也就导致了:我们在阅读完 ...

  7. 安卓开发_浅谈ListView(自定义适配器)

    ListView作为一个实际开发中使用率非常高的视图,一般的系统自带的适配器都无法满足开发中的需求,这时候就需要开发人员来自定义适配器使得ListView能够有一个不错的显示效果 有这样一个Demo ...

  8. 浅谈分词算法(4)基于字的分词方法(CRF)

    目录 前言 目录 条件随机场(conditional random field CRF) 核心点 线性链条件随机场 简化形式 CRF分词 CRF VS HMM 代码实现 训练代码 实验结果 参考文献 ...

  9. 【Vue】浅谈Vue不同场景下组件间的数据交流

    浅谈Vue不同场景下组件间的数据“交流”   Vue的官方文档可以说是很详细了.在我看来,它和react等其他框架文档一样,讲述的方式的更多的是“方法论”,而不是“场景论”,这也就导致了:我们在阅读完 ...

随机推荐

  1. webpack打包去除map文件及其他一些配置

    一.vue-cli(3.x)搭建的项目,webpack(3.x)打包时,生成的map文件很大,目前又不知道是干嘛用的,所以就直接去掉了. 方法: 修改sourceMap配置成为false. 1:在bu ...

  2. ubuntu16.04LTS更换阿里源

    ubuntu16.04LTS更换阿里源 sudo gedit /etc/apt/sources.list 替换:    # deb cdrom:[Ubuntu 16.04 LTS _Xenial Xe ...

  3. 关于wsgi协议的理解

    基础概念 首先要了解 WSGI 规范的概念,WSGI(Web Server Gateway Interface)规范描述了web server(Gunicorn,uWSGI等)如何与web appli ...

  4. IDEA项目搭建六——使用Eureka和Ribbon进行项目服务化

    一.Eureka的作用 这里先简单说明使用eureka进行业务层隔离,实现项目服务化也可以理解为微服务,我一直崇尚先实现代码再学习理论,先简单上手进行操作,eureka使用分为三块,1是服务注册中心, ...

  5. Openlayer3之空间参考扩展

    Openlayers默认了两种空间参考,一个是EPSG4326,一个是EPSG3857,其它的空间参考需要进行扩展才能使用.所以我们初始化时进行了如下操作: 1.将配置数据库中所有的空间参考读取出来, ...

  6. js判断当前浏览器语言类型

    console.log(window.navigator.language.slice(0, 2)); 得到的是zh

  7. spring资源访问接口和资源加载接口

    spring 资源访问接口 JDK提供的资源访问类,如java.net.URL.File等,不能很好地满足各种资源的访问需求,比如缺少从类路径或者Web容器的上下文中获取资源的操作类. 鉴于此,spr ...

  8. Expo大作战(三十)--expo sdk api之Permissions(权限管理模块),Pedometer(计步器api)

    简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网 我猜去全部机翻+个人 ...

  9. [Android] ubuntu 下不识别 Android 设备

    之前的android手机给家人用了,手里现在有一个旧手机,调试过程又出现不识别的问题,这次要记录一下. 首先,需要把手机开发者选项打开,在设置里对着android版本或者型号多点几次,就会打开. 原文 ...

  10. 使用VSTS的Git进行版本控制(六)——拉取请求

    使用VSTS的Git进行版本控制(六)--拉取请求 在将代码合并到主干之前,拉取请求让团队对特性分支的更改提供反馈.审阅人可以通过建议修改留下评论,并投票批准或拒绝代码. 任务1:在Visual St ...