JDBC與MyBatis

????????????????????????????????傳統(tǒng)的JDBC編程

JAVA程序通過JDBC鏈接數(shù)據(jù)庫,這樣我們就可以通過SQL對數(shù)據(jù)庫進行編程。

JAVA鏈接數(shù)據(jù)庫大致分為5步。

1.使用JDBC編程需要鏈接數(shù)據(jù)庫,注冊驅(qū)動和數(shù)據(jù)庫信息。

2.操作Connection,打開Statement對象。

3.通過Statement執(zhí)行SQL語句,返回結(jié)果放到ResultSet對象。

4.使用ResultSet讀取數(shù)據(jù)。

5.關(guān)閉數(shù)據(jù)庫相關(guān)的資源。


傳統(tǒng)的JDBC方式存在一些弊端,第一點,工作量比較大。我們需要先建立鏈接,然后處理JDBC底層業(yè)務(wù),處理數(shù)據(jù)類型。我們還需要處理Connection對象,Statement對象和Result對象去拿數(shù)據(jù),并關(guān)閉它們。第二點我們對JDBC編程處理的異常進行捕獲處理并正確的關(guān)閉資源。

????????????????????????????????????????MyBatis

首先我們先了解一下MyBatis的核心組件。

1.SQLSessionFactoryBuilder(構(gòu)造器):它會根據(jù)配置信息或者代碼生成SqlSessionFactory。

2.SqlSessionFactory(工程接口):依靠工程生成SqlSession。

3.SqlSession(會話):是一個既可以發(fā)送SQL去執(zhí)行并且返回結(jié)果,也可以獲取Mapper接口。

4.SQL Mapper:是由一個JAVA接口和XML文件(或注解)構(gòu)成,需要給出對應(yīng)的SQL和映射規(guī)則。SQL是由Mapper發(fā)送出去,并且返回結(jié)果。

總結(jié):

????????從上面的流程圖可以看出MyBatis和JDBC的執(zhí)行時相似的。Mybatis的實現(xiàn)原理就是對JDBC進行了封裝,將相應(yīng)的接口留給了程序員。只要程序員在配置文件中配置中填寫自己的數(shù)據(jù)庫類型,數(shù)據(jù)庫,數(shù)據(jù)表,用戶名,密碼,相應(yīng)的SQL語句,省去了創(chuàng)建連接,創(chuàng)建Statement對象和Result對象大大的提高了代碼復用性。MyBatis相對于JDBC執(zhí)行的速度相對較慢,因為JDBC更接近底層。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容