????????????????????????????????傳統的JDBC編程
JAVA程序通過JDBC鏈接數據庫,這樣我們就可以通過SQL對數據庫進行編程。
JAVA鏈接數據庫大致分為5步。
1.使用JDBC編程需要鏈接數據庫,注冊驅動和數據庫信息。
2.操作Connection,打開Statement對象。
3.通過Statement執行SQL語句,返回結果放到ResultSet對象。
4.使用ResultSet讀取數據。
5.關閉數據庫相關的資源。
傳統的JDBC方式存在一些弊端,第一點,工作量比較大。我們需要先建立鏈接,然后處理JDBC底層業務,處理數據類型。我們還需要處理Connection對象,Statement對象和Result對象去拿數據,并關閉它們。第二點我們對JDBC編程處理的異常進行捕獲處理并正確的關閉資源。
????????????????????????????????????????MyBatis
首先我們先了解一下MyBatis的核心組件。
1.SQLSessionFactoryBuilder(構造器):它會根據配置信息或者代碼生成SqlSessionFactory。
2.SqlSessionFactory(工程接口):依靠工程生成SqlSession。
3.SqlSession(會話):是一個既可以發送SQL去執行并且返回結果,也可以獲取Mapper接口。
4.SQL Mapper:是由一個JAVA接口和XML文件(或注解)構成,需要給出對應的SQL和映射規則。SQL是由Mapper發送出去,并且返回結果。
總結:
????????從上面的流程圖可以看出MyBatis和JDBC的執行時相似的。Mybatis的實現原理就是對JDBC進行了封裝,將相應的接口留給了程序員。只要程序員在配置文件中配置中填寫自己的數據庫類型,數據庫,數據表,用戶名,密碼,相應的SQL語句,省去了創建連接,創建Statement對象和Result對象大大的提高了代碼復用性。MyBatis相對于JDBC執行的速度相對較慢,因為JDBC更接近底層。