go語言mysql框架-開源輕量級數(shù)據(jù)庫訪問框架-Go語言中文社區(qū)_第1頁
go語言mysql框架-開源輕量級數(shù)據(jù)庫訪問框架-Go語言中文社區(qū)_第2頁
go語言mysql框架-開源輕量級數(shù)據(jù)庫訪問框架-Go語言中文社區(qū)_第3頁
go語言mysql框架-開源輕量級數(shù)據(jù)庫訪問框架-Go語言中文社區(qū)_第4頁
go語言mysql框架-開源輕量級數(shù)據(jù)庫訪問框架-Go語言中文社區(qū)_第5頁
已閱讀5頁,還剩1頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論