版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
go語?mysql框架_開源輕量級數(shù)據(jù)庫訪問框架-Go語?中?社區(qū)本框架為開源框架,旨在簡化?戶的數(shù)據(jù)庫操作,提供便捷的數(shù)據(jù)庫訪問服務(wù)?封裝。該框架依賴于JDBC,并且基于原?JAVASE框架的封裝??蚣軐?對于經(jīng)常進(jìn)?數(shù)據(jù)庫開發(fā)和JAVAEE開發(fā)的編程?員??,其最先使?到的數(shù)據(jù)持久化?式則為Hibernate,或者是使?JAVAEE或者SpringMVC等框架所?帶的數(shù)據(jù)庫緩沖池的?式,去管理數(shù)據(jù)庫的連接。然?,這些框架是?常優(yōu)秀的,但是卻顯得不夠輕量。?先很多JAVAEE框架都維持了?個(gè)數(shù)據(jù)庫連接的緩沖池,來管理數(shù)據(jù)庫的連接,使得在這個(gè)程序中,始終都可以存在可?的數(shù)據(jù)庫連接,從?避免了重復(fù)建?連接和釋放連接的性能上的損耗。并且數(shù)據(jù)庫連接的管理,不必交給程序員去維護(hù),?是將維護(hù)?作,交給了程序本?,使得其??可以監(jiān)控?cái)?shù)據(jù)庫連接,當(dāng)某個(gè)連接超過最?空閑時(shí)間時(shí),才將其釋放,并且在連接池中始終都保持著有不?于最?連接數(shù)的數(shù)據(jù)庫連接,等待著?戶的訪問和使?,但是這些連接?不會過度創(chuàng)建,它們始終被約束在了最?連接數(shù)之內(nèi),當(dāng)數(shù)據(jù)庫連接過多時(shí),則需要考慮是否有連接可?,否則需要等待其他?作的完成,從?降低了數(shù)據(jù)庫的壓?,提?了數(shù)據(jù)庫的性能,防??并發(fā)帶來的壓?。這在Web設(shè)計(jì)中是經(jīng)常使?的,并且是?種有效的解決?案,并且在Hibernate還提供了?效的緩存技術(shù)。然?這種?式,對于客戶端??,及并發(fā)要求不?,服務(wù)器資源不盡充?的條件下,是存在很?弊端的。在這種解決?案中,始終在連接池中維護(hù)了?定數(shù)量的連接池,供?戶重復(fù)使?,雖然其降低了創(chuàng)建連接和釋放連接的開銷,但是其需要始終在內(nèi)存中存在這些連接備不時(shí)之需,那么對服務(wù)器的內(nèi)存是?個(gè)很?的要求。并且在并發(fā)并不是很?的項(xiàng)?中,這些連接很可能不會經(jīng)常被使?,那么始終保持著連接,實(shí)際上也是在浪費(fèi)和占?資源,浪費(fèi)帶寬(數(shù)據(jù)庫服務(wù)和Web服務(wù)不在同?主機(jī))和浪費(fèi)內(nèi)存,那么這種解決?案的弊端,便顯現(xiàn)出來,并且始終管理連接池,也會需要開銷,此時(shí)的開銷不?定?重復(fù)創(chuàng)建和釋放連接的開銷?,因此在這種情形下,使?連接池并不是?種最優(yōu)的解決?案,?使?傳統(tǒng)的JDBC更加能提?數(shù)據(jù)庫訪問的效率,和節(jié)省不必要的資源消耗。以上便是該框架所擁有的優(yōu)勢和適?的情形。UML設(shè)計(jì)
該UML設(shè)計(jì)采?PowerDesigner進(jìn)?,并遵從UML規(guī)范進(jìn)?設(shè)計(jì)。在該框架中,涉及類為10個(gè):AbstractQueryObject:主要負(fù)責(zé)數(shù)據(jù)庫的操作,處理?戶提交的SQL請求,需要針對不同的業(yè)務(wù),創(chuàng)建實(shí)例化不同的?類進(jìn)?操作。DatabaseFactory:數(shù)據(jù)庫??,主要?戶創(chuàng)建不同的數(shù)據(jù)庫,在該接?中,只有?個(gè)databaseInfo?法,并且有多個(gè)重載版本,主要為適應(yīng)于本地?cái)?shù)據(jù)庫和遠(yuǎn)程數(shù)據(jù)庫DBBasicInfo:抽象基類,為數(shù)據(jù)庫的基本信息,數(shù)據(jù)庫名,?戶名,URL地址等信息為基本屬性,并且抽象出了url的get?法,使得?類??拼接JDBC的連接URLDBConnection:數(shù)據(jù)庫連接類,主要管理數(shù)據(jù)庫的連接,負(fù)責(zé)連接的創(chuàng)建(打開),關(guān)閉等操作IConnection:數(shù)據(jù)庫連接的接?,主要提供數(shù)據(jù)庫的連接操作接?Model:?具類,借助反射機(jī)制,將數(shù)據(jù)庫查詢結(jié)果依次解析為對應(yīng)的實(shí)體類MSSQLDBInfo:MicrosoftSQLServer數(shù)據(jù)庫信息,為DBBasicInfo的?類,?于SQLServer的基本信息的服務(wù)MSSQLFactory:MicrosoftSQLServer??類,可產(chǎn)?指定類型的SQLServer數(shù)據(jù)庫信息類,供其他類使?MySQLDBInfo:MySQL數(shù)據(jù)庫信息類,為DBBasicInfo?類,?于提供MySQL數(shù)據(jù)庫的基本信息MySQLFactory:MySQL數(shù)據(jù)庫??類,可產(chǎn)?指定的MySQL數(shù)據(jù)庫信息使??式?類化AbstractQueryObject類,并重載setupDatabase?法,在該?法中指定數(shù)據(jù)庫信息。提供??函數(shù)進(jìn)?測試使?。如:/***測試查詢類*@authorFrank**/publicfinalclassQueryObjectextendsAbstractQueryObject{/*(non-Javadoc)*@seeerfaces.AbstractQueryObject#setupDatabase()*/@OverridepublicvoidsetupDatabase(){DatabaseFactoryfactory=newMySQLFactory();DBBasicInfomysql=factory.databaseInfo("test");DBConnectionconnection=newDBConnection();mysql.setUsername("root");mysql.setPassword("123456");connection.setDbinfo(mysql);dbManager=connection;}privatefinalstaticStringSQL_CREATE_TABLE="CREATETABLETB_QUERY(idintprimarykey,contentchar(120)notnull);";/***?例,創(chuàng)建?個(gè)表*@return*/publicbooleancreateTable(){avoidNotBindDatabase();returnthis.update(SQL_CREATE_TABLE,newObject[0]);}}
使?JUnit4測試如下:publicclassTestUnit{@TestpublicvoidtestCreateTable(){QueryObjectquery=newQueryObject();if(!query.createTable()){fail("創(chuàng)建失敗!");}}}如此,即可完成對數(shù)據(jù)庫的操作,??需使?過多的語句進(jìn)?處理,也省去了繁瑣的?數(shù)據(jù)庫創(chuàng)建和連接的過程,所有的內(nèi)部過程都?動化進(jìn)?。注:該框架是依賴于JDBC的,因此在進(jìn)?數(shù)據(jù)庫操作時(shí),需要在BuildPath中引?對應(yīng)數(shù)據(jù)庫類型的JDBC驅(qū)動包,如MySQL需要提供MySQL的驅(qū)動。更優(yōu)雅的?式在于,重新創(chuàng)建?個(gè)抽象基類泛化?AbstractQueryObject類,并且重載該setupDatabase?法,在之后的數(shù)據(jù)庫訪問類中,都繼承?該抽象基類,并且實(shí)現(xiàn)業(yè)務(wù)所需要的接?。詳細(xì)請參照Demo中的實(shí)例代碼。未完善之處?前該框架,僅?持了MySQL和MSSQL數(shù)據(jù)庫,未適配Oracle等其他數(shù)據(jù)庫。但是對其他數(shù)據(jù)庫的適配也極其簡單,只需要遵照???法模式對DatabaseFactory進(jìn)??類化以創(chuàng)建不同的數(shù)據(jù)庫信息類,并且具體化DBBasicInfo類,重載其URL的拼接?法即可。重載完成之后,即可在setupDatabase?法中,指定數(shù)據(jù)庫的信息進(jìn)?數(shù)據(jù)庫的訪問和交互。Demo測試TueAug2315:10:13CST2016WARN:EstablishingSSLconnectionwithoutserver'sidentityverificationisnotrecommended.AccordingtoMySQL5.5.45+,5.6.26+and5.7.6+requirementsSSLconnectionmustbeestablishedbydefaultifexplicitoptionisn'tset.ForcompliancewithexistingapplicationsnotusingSSLtheverifyServerCertificatepropertyissetto'false'.YouneedeithertoexplicitlydisableSSLbysettinguseSSL=false,orsetuseSSL=trueandprovidetruststoreforservercertificateverification.創(chuàng)建成功!TueAug2315:10:14CST2016WARN:EstablishingSSLconnectionwithoutserver'sidentityverificationisnotrecommended.AccordingtoMySQL5.5.45+,5.6.26+and5.7.6+requirementsSSLconnectionmustbeestablishedbydefaultifexplicitoptionisn'tset.ForcompliancewithexistingapplicationsnotusingSSLtheverifyServerCertificatepropertyissetto'false'.YouneedeithertoexplicitlydisableSSLbysettinguseSSL=false,orsetuseSSL=trueandprovidetruststoreforservercertificateverification.插?成功!TueAug2315:10:14CST2016WARN:EstablishingSSLconnectionwithoutserver'sidentityverificationisnotrecommended.AccordingtoMySQL5.5.45+,5.6.26+and5.7.6+requirementsSSLconnectionmustbeestablishedbydefaultifexplicitoptionisn'tset.ForcompliancewithexistingapplicationsnotusingSSLtheverifyServerCertificatepropertyissetto'false'.YouneedeithertoexplicitlydisableSSLbysettinguseSSL=false,orsetuseSSL=trueandprovidetruststoreforservercertificateverification.[TableModel[id=1,content=測試實(shí)例1],TableModel[id=2,content=測試實(shí)例2]]
TueAug2315:10:15CST2016WARN:EstablishingSSLconnectionwithoutserver'sidentityverificationisnotrecommended.AccordingtoMySQL5.5.45+,5.6.26+and5.7.6+requirementsSSLconnectionmustbeestablishedbydefaultifexplicitoptionisn'tset.ForcompliancewithexistingapplicationsnotusingSSLtheverifyServerCertificatepropertyissetto'false'.YouneedeithertoexplicitlydisableSSLbysettinguseSSL=false,orsetuseSSL=trueandprovidetruststoreforservercertificateverification.更新成功!TueAug2315:10:15CST2016WARN:EstablishingSSLconnectionwithoutserver'sidentityverificationisnotrecommended.AccordingtoMySQL5.5.45+,5.6.26+and5.7.6+requirementsSSLconnectionmustbeestablishedbydefaultifexplicitoptionisn'tset.ForcompliancewithexistingapplicationsnotusingSSLtheverifyServerCertificatepropertyissetto'false'.YouneedeithertoexplicitlydisableSSLbysettinguseSSL=false,orsetuseSSL=trueandprovidetruststoreforservercertificateverification.[TableModel[id=1,content=新內(nèi)容],TableModel[id=2,content=測試實(shí)例2]]TueAug2315:10:15CST20
溫馨提示
- 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025-2030湘菜行業(yè)政策扶持與企業(yè)發(fā)展戰(zhàn)略
- 2025-2030清潔能源設(shè)備行業(yè)全球市場發(fā)展現(xiàn)狀及規(guī)劃
- 餐飲后廚人員崗位職責(zé)與制度
- 2025-2030消防安全設(shè)備行業(yè)技術(shù)標(biāo)準(zhǔn)市場競爭力評估報(bào)告
- 2025-2030消防人員作業(yè)防護(hù)感知度實(shí)驗(yàn)指標(biāo)優(yōu)化與全身式救援裝備評鑒
- 2025-2030消費(fèi)級無人機(jī)適航認(rèn)證標(biāo)準(zhǔn)完善與空域管理政策調(diào)整影響報(bào)告
- 2025-2030消費(fèi)級基因檢測市場教育策略與行業(yè)監(jiān)管趨勢預(yù)測報(bào)告
- 2025-2030消費(fèi)級AR眼鏡用戶體驗(yàn)痛點(diǎn)分析與硬件迭代方向預(yù)測報(bào)告
- 2025-2030消費(fèi)級AR眼鏡光學(xué)顯示方案對比與用戶體驗(yàn)研究
- 2025-2030消費(fèi)級3D打印材料創(chuàng)新趨勢與個(gè)性化定制市場培育策略
- 2026年榆能集團(tuán)陜西精益化工有限公司招聘備考題庫完整答案詳解
- 2026廣東省環(huán)境科學(xué)研究院招聘專業(yè)技術(shù)人員16人筆試參考題庫及答案解析
- 邊坡支護(hù)安全監(jiān)理實(shí)施細(xì)則范文(3篇)
- 6.1.3化學(xué)反應(yīng)速率與反應(yīng)限度(第3課時(shí) 化學(xué)反應(yīng)的限度) 課件 高中化學(xué)新蘇教版必修第二冊(2022-2023學(xué)年)
- 北京市西城區(qū)第8中學(xué)2026屆生物高二上期末學(xué)業(yè)質(zhì)量監(jiān)測模擬試題含解析
- 2026年遼寧輕工職業(yè)學(xué)院單招綜合素質(zhì)考試參考題庫帶答案解析
- 2026屆北京市清華大學(xué)附中數(shù)學(xué)高二上期末調(diào)研模擬試題含解析
- 醫(yī)院實(shí)習(xí)生安全培訓(xùn)課課件
- 四川省成都市武侯區(qū)西川中學(xué)2024-2025學(xué)年八上期末數(shù)學(xué)試卷(解析版)
- (售后服務(wù)方案)物料、設(shè)備采購售后服務(wù)方案
- 施工現(xiàn)場車輛進(jìn)出沖洗記錄
評論
0/150
提交評論