下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、 5/5Activiti連接達(dá)夢數(shù)據(jù)庫 目錄 1 環(huán)境準(zhǔn)備 (1) 2 創(chuàng)建SQL腳本 (1) 3 下載所需依賴包 (2) 3.1IDEA配置使用阿里云MAVEN倉庫 (2) 3.2下載所有依賴包 (5) 4 修改配置文件 (5) 4.1修改APPLICATION.PROPERTIES文件 (5) 4.2修改POM.XML文件 (6) 5 加載DM驅(qū)動程序 (6) 5.1拷貝DM驅(qū)動程序 (6) 5.2將驅(qū)動程序打入M AVEN倉庫 (7) 6 修改ACTIVITY-ENGINE-5.22.0 (8) 6.1修改P ROCESS E NGINE C ONFIGURATION I MPL文件 (
2、9) 6.2修改D B S QL S ESSION F ACTORY文件 (9) 6.3修改A BSTRACT Q UERY文件 (10) 7 ACTIVITY-ENGINE-5.22.0打包 (11) 8 驗(yàn)證結(jié)果 (12) 9 附錄 (12) 1環(huán)境準(zhǔn)備 項(xiàng)目名稱:Spring boot整合activiti工作流引擎實(shí)例 Spring-Boot-Activiti5.22.0項(xiàng)目文件:Spring-Boot-Activiti5.22.0.zip 開發(fā)工具:IntelliJ IDEA 2020.2 (Ultimate Edition) IDEA安裝路徑:D:IDEA 項(xiàng)目路徑:D:IDEAwo
3、rk 將項(xiàng)目文件解壓至D:IDEAwork目錄下,并導(dǎo)入IDEA: 2創(chuàng)建SQL腳本 將項(xiàng)目中activiti.sql腳本在數(shù)據(jù)庫中創(chuàng)建。 說明:項(xiàng)目中activiti.sql腳本是Mysql的語法,可先在Mysql中創(chuàng)建,再通過DTS工具遷移至DM中。也可使用以下activiti.sql直接在DM中創(chuàng)建(以下activiti.sql語法已修改為DM語法)。 DM語法activiti.sql腳本:activiti.sql 3下載所需依賴包 3.1IDEA配置使用阿里云maven倉庫 IDEA工具左上角:文件設(shè)置構(gòu)建、執(zhí)行、部署構(gòu)建工具M(jìn)aven 指定以下三個目錄: Maven主目錄(H): D
4、:/IDEA/plugins/maven/lib/maven3 用戶設(shè)置文件(S): D:IDEApluginsmavenlibmaven3confsettings.xml 本地存儲庫(R):C:UsersAdministrator.m2repository 在D:IDEApluginsmavenlibmaven3confsettings.xml文件中新增以下內(nèi)容,使用阿里云maven倉庫: central 3.2下載所有依賴包 4修改配置文件 4.1修改perties文件 將配置文件中數(shù)據(jù)源部分,改為達(dá)夢數(shù)據(jù)源: # datasource spring.datasource.url=jdbc
5、:dm:/:5236 spring.datasource.driver-class-name=dm.jdbc.driver.DmDriver http:/./doc/2e4cb966a1116c175f0e7cd184254b35effd1ad0.html ername=SYSDBA spring.datasource.password=SYSDBA 4.2修改pom.xml文件 在配置文件中新增達(dá)夢驅(qū)動部分: 1.8.0 5加載DM驅(qū)動程序 5.1拷貝DM驅(qū)動程序 達(dá)夢數(shù)據(jù)庫驅(qū)動無法通過maven在線下載。所以通過將DM8的驅(qū)動程序加載到Maven倉庫中實(shí)現(xiàn),使用的驅(qū)動程序如下: 注意:Dm
6、JdbcDriver18.jar等名字和springboot不兼容。需要試用DmJdbcDriver.jar這個名字。 將驅(qū)動程序拷貝到Maven倉庫中,并自定義創(chuàng)建對應(yīng)的路徑(紅色字體需要自己創(chuàng)建)。本示例路徑在: C:UsersAdministrator.m2repositorycomdmDmJdbcDriver1.8.0DmJdbcDriver.j ar 5.2將驅(qū)動程序打入Maven倉庫 使用mvn.cmd工具將DM8驅(qū)動程序打入Maven倉庫,mvn.cmd工具在:D:IDEApluginsmavenlibmaven3bin目錄下,通過以下命令進(jìn)行打入Maven倉庫: mvn.cmd
7、 install:install-file -DgroupId=com.dm -DartifactId=DmJdbcDriver -Dversion=1.8.0 -Dpackaging=jar - Dfile=C:UsersAdministrator.m2repositorycomdmDmJdbcDriver1.8.0DmJdbcD river.jar 點(diǎn)擊重新加載,DM驅(qū)動程序就不報錯了。 6修改Activity-engine-5.22.0 將activiti-engine-5.22.0相關(guān)源碼拷貝到工程src下,保持包路徑不變,并做相應(yīng)修改以支持達(dá)夢數(shù)據(jù)庫。 6.1修改ProcessEng
8、ineConfigurationImpl文件 在org.activiti.engine.impl.cfg.ProcessEngineConfigurationImpl文件中,增加標(biāo)紅部分: public static final String DATABASE_TYPE_DM = dm; public static final String DATABASE_TYPE_H2 = h2; public static final String DATABASE_TYPE_HSQL = hsql; public static final String DATABASE_TYPE_MYSQL = my
9、sql; public static final String DATABASE_TYPE_ORACLE = oracle; protected static Properties getDefaultDatabaseTypeMappings() Properties databaseTypeMappings = new Properties(); databaseTypeMappings.setProperty(DM DBMS, DATABASE_TYPE_DM); databaseTypeMappings.setProperty(H2, DATABASE_TYPE_H2); 6.2修改Db
10、SqlSessionFactory文件 在org.activiti.engine.impl.db.DbSqlSessionFactory文件中,增加標(biāo)紅部分:if (oracle.equals(databaseType) | dm.equals(databaseType) bulkInsertableMap.put(EventLogEntryEntity.class, Boolean.FALSE); 在org.activiti.engine.impl.db.DbSqlSessionFactory文件中,增加標(biāo)紅部分:/ dm databaseSpecificLimitBeforeStateme
11、nts.put(dm, ); databaseSpecificLimitAfterStatements.put(dm, LIMIT #maxResults OFFSET #firstResult); databaseSpecificLimitBetweenStatements.put(dm, ); databaseOuterJoinLimitBetweenStatements.put(dm, ); databaseSpecificOrderByStatements.put(dm, defaultOrderBy); / h2 databaseSpecificLimitBeforeStatemen
12、ts.put(h2, ); databaseSpecificLimitAfterStatements.put(h2, LIMIT #maxResults OFFSET #firstResult); databaseSpecificLimitBetweenStatements.put(h2, ); databaseOuterJoinLimitBetweenStatements.put(h2, ); databaseSpecificOrderByStatements.put(h2, defaultOrderBy); 6.3修改AbstractQuery文件 在org.activiti.engine
13、.impl.AbstractQuery文件中,增加標(biāo)紅部分(2處):if (nullHandlingOnOrder.equals(NullHandlingOnOrder.NULLS_FIRST) if (ProcessEngineConfigurationImpl.DATABASE_TYPE_H2.equals(databaseType) | ProcessEngineConfigurationImpl.DATABASE_TYPE_HSQL.equals(databaseType) | ProcessEngineConfigurationImpl.DATABASE_TYPE_POSTGRES.
14、equals(databaseType) | ProcessEngineConfigurationImpl.DATABASE_TYPE_ORACLE.equals(databaseType) | ProcessEngineConfigurationImpl.DATABASE_TYPE_DM.equals(databaseType) orderBy = orderBy + defaultOrderByClause + NULLS FIRST; else if (ProcessEngineConfigurationImpl.DATABASE_TYPE_MYSQL.equals(databaseTy
15、pe) orderBy = orderBy + isnull( + column + ) desc, + defaultOrderByClause; else if (ProcessEngineConfigurationImpl.DATABASE_TYPE_DB2.equals(databaseType) | ProcessEngineConfigurationImpl.DATABASE_TYPE_MSSQL.equals(databaseType) orderBy = orderBy + case when + column + is null then 0 else 1 end, + de
16、faultOrderByClause; else orderBy = orderBy + defaultOrderByClause; else if (nullHandlingOnOrder.equals(NullHandlingOnOrder.NULLS_LAST) if (ProcessEngineConfigurationImpl.DATABASE_TYPE_H2.equals(databaseType) | ProcessEngineConfigurationImpl.DATABASE_TYPE_HSQL.equals(databaseType) | ProcessEngineConf
17、igurationImpl.DATABASE_TYPE_POSTGRES.equals(databaseType) | ProcessEngineConfigurationImpl.DATABASE_TYPE_ORACLE.equals(databaseType) | ProcessEngineConfigurationImpl.DATABASE_TYPE_DM.equals(databaseType) orderBy = orderBy + column + + sortOrder + NULLS LAST; else if (ProcessEngineConfigurationImpl.D
18、ATABASE_TYPE_MYSQL.equals(databaseType) orderBy = orderBy + isnull( + column + ) asc, + defaultOrderByClause; else if (ProcessEngineConfigurationImpl.DATABASE_TYPE_DB2.equals(databaseType) | ProcessEngineConfigurationImpl.DATABASE_TYPE_MSSQL.equals(databaseType) orderBy = orderBy + case when + column + is null then 1 else 0 end, + defaultOrderByClause; else orderBy = orderBy + defaultOrderByClau
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026年湖南機(jī)電職業(yè)技術(shù)學(xué)院單招職業(yè)技能測試題庫及參考答案詳解一套
- 2026年河北青年管理干部學(xué)院單招職業(yè)傾向性考試題庫含答案詳解
- 2026年湖南外國語職業(yè)學(xué)院單招綜合素質(zhì)考試題庫及參考答案詳解
- 四川省成都市蓉城名校聯(lián)盟2024-2025學(xué)年高二上學(xué)期期中考試政治考試政治參考答案及評分標(biāo)準(zhǔn)
- 云南稅務(wù)面試題目及答案
- 安全攻防面試題及答案
- 2025~2026學(xué)年濟(jì)南天橋區(qū)濼口實(shí)驗(yàn)學(xué)校九年級上學(xué)期12月份物理考試試卷以及答案
- 2019年7月國開電大行管專科《監(jiān)督學(xué)》期末紙質(zhì)考試試題及答案
- 質(zhì)量檢驗(yàn)員培訓(xùn)
- 2025年臺州市中醫(yī)院衛(wèi)技高層次人才公開招聘備考題庫及參考答案詳解
- 2025年中小學(xué)生趣味百科知識競賽題庫及答案
- 銀行理財經(jīng)理先進(jìn)工作事跡材料
- 自動化控制系統(tǒng)調(diào)試預(yù)案
- 警務(wù)實(shí)戰(zhàn)執(zhí)法用語課件
- “無廢校園”建設(shè)指引
- 蔬菜種植記課件
- 操作系統(tǒng)期末考試試題及答案
- 引體向上教學(xué)課件下載
- 典型刑事案件匯報課件
- 醫(yī)院體檢中心主任競聘演講
- 外科手術(shù)病歷書寫規(guī)范與要點(diǎn)
評論
0/150
提交評論