所屬欄目:計算機信息管理論文 發(fā)布日期:2021-10-19 10:02 熱度:
在互聯(lián)網(wǎng)技術(shù)飛速發(fā)展的今天,為了提升企業(yè)的經(jīng)營效率、降低管理成本,越來越多的企業(yè)致力于投入資金和人力建立符合自身業(yè)務(wù)需要的信息系統(tǒng)。在企業(yè)級信息系統(tǒng)的設(shè)計思想領(lǐng)域,Java EE的三層架構(gòu)思想一直占有著主導(dǎo)地位。表現(xiàn)層負責(zé)將數(shù)據(jù)以用戶需要的形式進行展示;業(yè)務(wù)邏輯層針對具體的問題,調(diào)用Service或Service的組合來處理問題;數(shù)據(jù)訪問層則負責(zé)操作數(shù)據(jù)庫、完成具體的實現(xiàn)。數(shù)據(jù)訪問層的代碼具有結(jié)構(gòu)相似、重復(fù)率高的特點,縮短數(shù)據(jù)訪問層的開發(fā)周期具有重要意義,闡釋了利用逆向工程工具生成數(shù)據(jù)訪問層的代碼,這種策略能夠大幅縮短數(shù)據(jù)訪問層的開發(fā)周期、提高開發(fā)效率。
1 研究的背景及意義
在互聯(lián)網(wǎng)技術(shù)飛速發(fā)展的今天,為了提升企業(yè)的經(jīng)營效率、降低管理成本,越來越多的企業(yè)致力于投入資金和人力建立符合自身業(yè)務(wù)需要的信息系統(tǒng)。在企業(yè)級信息系統(tǒng)的設(shè)計思想領(lǐng)域,Java EE的三層架構(gòu)思想一直占有著主導(dǎo)地位。近20年來,占有率最高的技術(shù)組合從最初的JSP+Servlet+DAO,變成了SSH,然后是SSM,到最近的Spring Boot、Spring Cloud,無論哪一種技術(shù)組合,都在三層架構(gòu)的思想下進行設(shè)計和編碼,即:表現(xiàn)層負責(zé)將數(shù)據(jù)以用戶需要的形式進行展示;業(yè)務(wù)邏輯層針對具體的問題,調(diào)用Service或Service的組合來處理問題;數(shù)據(jù)訪問層則負責(zé)操作數(shù)據(jù)庫、完成具體的Service實現(xiàn)。對大量系統(tǒng)項目的代碼進行分析和比較后不難發(fā)現(xiàn),數(shù)據(jù)訪問層具有以下特點:
(1)代碼量占比相對較高。數(shù)據(jù)訪問層代碼量大概占整個系統(tǒng)編碼總量的20%~30%;在以數(shù)據(jù)分析、統(tǒng)計為主要功能的系統(tǒng)中,數(shù)據(jù)訪問層的代碼占比甚至能到達40%。
(2)代碼的重復(fù)率較高。不管DAO層包含多少張數(shù)據(jù)表,對它們進行Create、Retrieve、Update、Delete4種操作的語句的語法、結(jié)構(gòu)都是相同的,差異僅在于表名、參數(shù)等部分,這使得DAO層的代碼重復(fù)率、相似度非常高。
從軟件開發(fā)者的角度看,DAO層的代碼若采用人工編寫的方式編寫,盡管可行,但創(chuàng)造性勞動較少,是一個相對冗長、乏味的過程。若能找到一種自動化的方法完成上述編碼工作,至少有以下兩個方面的好處:(1)從程序員的角度看,能夠免去冗長、乏味的編碼過程,從而有更多精力專注于業(yè)務(wù)邏輯、用戶界面、用戶體驗等部分;(2)從企業(yè)的角度看,能夠降低DAO層的開發(fā)周期、減少所需的人力、節(jié)省成本。
逆向工程是從已完成的產(chǎn)品或系統(tǒng)出發(fā),借助各種工具進行分析和研究,進而推導(dǎo)出該產(chǎn)品的處理流程、組織結(jié)構(gòu)、功能特性、技術(shù)規(guī)格等設(shè)計要素的技術(shù)。與直接開發(fā)相比,借助逆向工程技術(shù)來開發(fā)能在一定程度上縮短開發(fā)周期、減少投入經(jīng)費、減少人力成本,并取得功能相似的產(chǎn)品。以My Eclipse、Oracle數(shù)據(jù)庫為例,闡釋如何采用逆向工程技術(shù)自動實現(xiàn)上述目標。
2 逆向工程技術(shù)使用流程
2.1 在IDE中添加逆向工程插件
以My Eclipse 2017、Hibernate框架為例,添加插件的步驟為:在My Eclipse的Project Explorer中選中項目,右鍵菜單【Configure Facets】-->【Install Hibernate Facet】,即完成了逆向工程插件的添加。
2.2 創(chuàng)建數(shù)據(jù)庫、表結(jié)構(gòu)、表約束
以租房信息管理系統(tǒng)的表結(jié)構(gòu)為例,將被執(zhí)行逆向工程的表的結(jié)構(gòu)信息如下:
(1)用戶表User (ID,Name,Password,Telephone,Use-rname)
(2)房屋類型表Type (ID,Name)
(3)街道表Street (ID,Name,district_id)
(4)區(qū)表District (ID,Name)
(5)房屋表House (ID,User_id,type_id,street_id,ti-tle,price,floorage,imge)
用下劃線標記的字段為主鍵;用波浪線標記的字段為外鍵。
2.3 利用逆向工程工具生成DAO層代碼
2.3.1 開啟Database Explorer
在My Eclipse 207中依次選擇菜單【W(wǎng)indow】-->【Perspective】-->【Open Perspective】-->【Database Explorer】。
2.3.2 添加Oracle數(shù)據(jù)庫連接
在【DB Browser】中依次選擇菜單【New】-->【輸入數(shù)據(jù)庫配置信息(驅(qū)動信息、連接URL、用戶名、密碼)】-->【連接】,可連接上數(shù)據(jù)庫并查看到所有的Schema和數(shù)據(jù)庫對象。
2.3.3 對表使用逆向工程
在Schema中找到要執(zhí)行逆向工程的5張表。然后右鍵菜單【Hibernate Reversing Engineering】--設(shè)置生成的DAO層代碼保存路徑--Finish,即可完成DAO層代碼的生成。
上述5表生成的DAO層主要類如下:
(1) District DAO,持久化操作District表。(2)House DAO表,持久化操作House表。(3) Street DAO,持久化操作Street表。(4) User DAO,持久化操作User表。(5) Type DAO,持久化操作Type表。(6) Hibernate Session Factory,創(chuàng)建Sessesion Factory。(7) BaseHibernate DAO,基類,提供訪問數(shù)據(jù)庫所需的Session。
3 對DAO層代碼進行必要調(diào)整、集成到系統(tǒng)
3.1 代碼調(diào)整
逆向工程工具生成的DAO類的基本成員類型,有時會需要進行必要的調(diào)整,調(diào)整主要涉及到兩個方面:
3.1.1 DAO類基本屬性類型的調(diào)整
例如,DAO類代碼中映射主鍵的ID字段的類型為Java.lang.Double,大多情況下調(diào)整為Java.lang.Integer較合適。
3.1.2 手動創(chuàng)建某些名稱特殊的DAO類
例如,數(shù)據(jù)庫中房屋類型Type表,由于Type類為Jdk中已有的類,因而無法生成Type.java和Type DAO.java。這種情況下,只能手動創(chuàng)建Type.java、Type DAO.java。當(dāng)逆向工程工具遇到名字特殊的表時,不能正常生成。解決這個問題的方式是,預(yù)先將表的名稱修改成非特殊名稱,然后再使用逆向工程工具。
3.2 集成到系統(tǒng)
根據(jù)是否系統(tǒng)是否采用了Spring,集成方式分為以下兩種情況:未采用Spring的系統(tǒng)、采用了Spring的系統(tǒng)。
3.2.1 未采用Spring的系統(tǒng)
可直接集成。即,在服務(wù)層直接使用new的方式創(chuàng)建DAO對象,然后對相應(yīng)的表進行持久化操作。
3.2.2 采用了Spring的系統(tǒng)
采用了Spring的系統(tǒng),Spring的IOC容器中創(chuàng)建并維護著操作數(shù)據(jù)庫所需的Session Factory Bean。在這種情形下,DAO對象中的Session Factory應(yīng)采用用自動裝配的方式從Spring的IOC容器中獲取Session Factory,不再采用new的方式創(chuàng)建。
3.3 在DAO中添加自定義的數(shù)據(jù)庫訪問方法
通過逆向工程工具生成的DAO類中具備方法較多,常用的如下(以House DAO為例):
(1) void delete (House),刪除House對象對應(yīng)的記錄。(2) List find All(),查詢House表中的所有記錄。(3) List find By Example (House),查詢House表中屬性與參數(shù)匹配的記錄。(4) List find By Property (String,Object),根據(jù)屬性名、屬性值查詢表中能匹配的記錄。(5) House merge (House),將傳入的托管態(tài)的對象的屬性復(fù)制到持久化對象中,并返回持久化對象。(6) void save (House),根據(jù)House對象在表中插入新紀錄。
4 結(jié)語
逆向工程工具的采用使得數(shù)據(jù)訪問層代碼的生產(chǎn)方式從人工編寫轉(zhuǎn)變成了自動生成,大幅地提高了開發(fā)效率、縮短了編碼周期,從而使得開發(fā)人員能夠?qū)⒏嗟木W⒂跇I(yè)務(wù)層、用戶界面、用戶體驗的工作,具有相當(dāng)?shù)氖褂脙r值。
參考文獻
[1]王奎.基于SSM框架的Java Web開發(fā)課程教學(xué)中的幾點思考[J].電腦知識與技術(shù),2018,(27).
[2]吳官學(xué)基于Spring MVC酒店信息管理系統(tǒng)[D].吉林大學(xué)2018.
[3]葛萌基于Spring MVC框架的Java Web應(yīng)用[J].計算機與現(xiàn)代化,2018.(08).
《逆向工程技術(shù)在信息系統(tǒng)開發(fā)中的應(yīng)用》來源:《電腦編程技巧與維護》,作者:高新凱
文章標題:逆向工程技術(shù)在信息系統(tǒng)開發(fā)中的應(yīng)用
轉(zhuǎn)載請注明來自:http://m.56st48f.cn/fblw/dianxin/xinxiguanli/46938.html
攝影藝術(shù)領(lǐng)域AHCI期刊推薦《Phot...關(guān)注:105
Nature旗下多學(xué)科子刊Nature Com...關(guān)注:152
中小學(xué)教師值得了解,這些教育學(xué)...關(guān)注:47
2025年寫管理學(xué)論文可以用的19個...關(guān)注:192
測繪領(lǐng)域科技核心期刊選擇 輕松拿...關(guān)注:64
及時開論文檢索證明很重要關(guān)注:52
中國水產(chǎn)科學(xué)期刊是核心期刊嗎關(guān)注:54
國際出書需要了解的問題解答關(guān)注:58
合著出書能否評職稱?關(guān)注:48
電信學(xué)有哪些可投稿的SCI期刊,值...關(guān)注:66
通信工程行業(yè)論文選題關(guān)注:73
SCIE、ESCI、SSCI和AHCI期刊目錄...關(guān)注:120
評職稱發(fā)論文好還是出書好關(guān)注:68
復(fù)印報刊資料重要轉(zhuǎn)載來源期刊(...關(guān)注:51
英文期刊審稿常見的論文狀態(tài)及其...關(guān)注:69
Web of Science 核心合集期刊評估...關(guān)注:58
電子信息論文范文
智能科學(xué)技術(shù)論文 廣播電視論文 光電技術(shù)論文 計算機信息管理論文 計算機網(wǎng)絡(luò)論文 計算機應(yīng)用論文 通信論文 信息安全論文 微電子應(yīng)用論文 電子技術(shù)論文 生物醫(yī)學(xué)工程論文 軟件開發(fā)論文
期刊百科問答
copyright © m.56st48f.cn, All Rights Reserved
搜論文知識網(wǎng) 冀ICP備15021333號-3