多數據源方案是針對每個庫都生成一個新的dao對象,不同的庫操作用不同的dao對象。
1、ds-dbcp.xml、transaction.xml分別復制一份,然后文件內部ID及引用都改成新的,以免spring實例ID重復報錯
2、spring-config.xml引入新的ds-dbcp-xx.xml文件
3、規范目的,resources目錄sql下新建對應庫的目錄,ds-dbcp-xx.xml中xxSqlSessionFactory的sqlLocations改成此目錄
4、application.properties文件中加入新庫的屬性配置,然后ds-dbcp-xx.xml中做修改
application.properties中加入
```
ds.ds_gis.driverClassName=org.postgresql.Driver
ds.ds_gis.url=jdbc:postgresql://ip:port/gisjs
ds.ds_gis.username=xxuser
ds.ds_gis.password=xx
ds.ds_gis.validationQuery=select 1
ds.ds_gis.maxActive=30
ds.ds_gis.maxIdle=20
ds.ds_gis.initialSize=10
```
ds-dbcp-xx.xml中修改
```
<!-- 數據源ds_gis -->
<bean id="ds_gis" class="org.walkframework.tools.jdbc.SecurityDbcpBasicDataSource" destroy-method="close">
<property name="driverClassName" value="${ds.ds_gis.driverClassName}"/>
<property name="url" value="${ds.ds_gis.url}" />
<property name="username" value="${ds.ds_gis.username}" />
<property name="password" value="${ds.ds_gis.password}" />
<property name="validationQuery" value="${ds.ds_gis.validationQuery}"/>
<property name="maxActive" value="${ds.ds_gis.maxActive}" />
<property name="maxIdle" value="${ds.ds_gis.maxIdle}" />
<property name="initialSize" value="${ds.ds_gis.initialSize}" />
</bean>
```
5、service中使用
```
@Resource(name = "sqlSessionDao")
private BaseSqlSessionDao dao;
@Resource(name = "gisSqlSessionDao")
private BaseSqlSessionDao gisdao;
```
- walk簡介
- 核心模塊
- walk-data
- IData
- EntityHelper
- walk-cache
- 緩存管理器
- 緩存對象
- 緩存注解
- walk-batis
- 單表操作
- 批量操作
- 列表/分頁查詢
- 所有方法列表
- sql熱部署
- 二級緩存
- 數據庫方言
- 其他使用技巧
- 實體類生成工具
- walk-mq
- 隊列管理器
- 隊列對象
- 訂閱/發布管理器
- 訂閱器
- 發布器
- walk-shiro
- 用戶認證/授權
- url動態授權/回收
- 分布式會話
- 無狀態會話支持
- walk-base
- 前端基礎框架
- 公共頁面
- 自定義標簽
- 自定義函數
- 組件及工具
- 后端基礎框架
- 基礎結構
- 表單校驗
- 數據導入
- 數據導出
- 上傳下載
- 靜態參數加載器
- 靜態參數翻譯器
- 實體類翻譯器
- sql翻譯器
- 自定義翻譯器
- 靜態參數校驗器
- 分布式任務
- 增刪改查代碼生成器
- walk-restful
- 請求報文
- 返回報文
- 節點翻譯器
- api代碼生成
- walk-activiti
- 接口封裝
- 模型管理
- 流程圖展示
- 集成方法
- walk-console
- 在線會話管理
- 靜態參數表緩存管理
- 緩存管理
- 隊列管理
- 發布/訂閱管理
- walk-boot
- 常用功能
- 持久層操作
- 分布式緩存
- 分布式會話
- 分布式任務
- 前端常用功能
- 后端常用功能
- 工作流封裝
- 多數據源支持
- 關于讀寫分離
- 常用工具類
- 代碼生成工具
- SpringCloud集成
- 阿里edas平臺支持
- 其他
- 開發規約
- 環境要求
- 工程示例
- 工程結構
- web工程
- API工程
- 后臺任務
- 常見問題
- 事務不生效
- 分布式任務不生效
- 事務鎖
- 變更歷史