一、Mybatis是什么
?
MyBatis是一個支持普通SQL查詢,存儲過程和高級映射的優秀持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數的手工設置以及對結果集的檢索封裝。MyBatis可以使用簡單的XML或注解用于配置和原始映射,將接口和Java的POJO(Plain Old Java Objects,普通的Java對象)映射成數據庫中的記錄。
1、Mybatis實現了接口綁定,使用更加方便。
在ibatis2.x中我們需要在DAO的實現類中指定具體對應哪個xml映射文件, 而Mybatis實現了DAO接口與xml映射文件的綁定,自動為我們生成接口的具體實現,使用起來變得更加省事和方便。
2、對象關系映射的改進,效率更高
3、MyBatis采用功能強大的基于OGNL的表達式來消除其他元素。
對于IBatis與MyBatis的區別就不再多說了,感興趣的朋友可以研究一下
MyBatis的框架架構
?
看到Mybatis的框架圖,可以清晰的看到Mybatis的整體核心對象,我更喜歡用自己的圖來表達Mybatis的整個的執行流程。如下圖所示:
?
原理詳解:
MyBatis應用程序根據XML配置文件創建SqlSessionFactory,SqlSessionFactory在根據配置,配置來源于兩個地方,一處是配置文件,一處是Java代碼的注解,獲取一個SqlSession。SqlSession包含了執行sql所需要的所有方法,可以通過SqlSession實例直接運行映射的sql語句,完成對數據的增刪改查和事務提交等,用完之后關閉SqlSession。
MyBatis的優缺點詳解
優點:
1、簡單易學
mybatis本身就很小且簡單。沒有任何第三方依賴,最簡單安裝只要兩個jar文件+配置幾個sql映射文件易于學習,易于使用,通過文檔和源代碼,可以比較完全的掌握它的設計思路和實現
2、靈活
mybatis不會對應用程序或者數據庫的現有設計強加任何影響。 sql寫在xml里,便于統一管理和優化。通過sql基本上可以實現我們不使用數據訪問框架可以實現的所有功能,或許更多。
通過提供DAL層,將業務邏輯和數據訪問邏輯分離,使系統的設計更清晰,更易維護,更易單元測試。sql和代碼的分離,提高了可維護性。
4、提供映射標簽,支持對象與數據庫的orm字段關系映射
5、提供對象關系映射標簽,支持對象關系組建維護
6、提供xml標簽,支持編寫動態sql。
缺點:
1、編寫SQL語句時工作量很大,尤其是字段多、關聯表多時,更是如此。
2、SQL語句依賴于數據庫,導致數據庫移植性差,不能更換數據庫。
3、框架還是比較簡陋,功能尚有缺失,雖然簡化了數據綁定代碼,但是整個底層數據庫查詢實際還是要自己寫的,工作量也比較大,而且不太容易適應快速數據庫修改。
4、二級緩存機制不佳
小結
mybatis的優點同樣是mybatis的缺點,正因為mybatis使用簡單,數據的可靠性、完整性的瓶頸便更多依賴于程序員對sql的使用水平上了。sql寫在xml里,雖然方便了修改、優化和統一瀏覽,但可讀性很低,調試也非常困難,也非常受限。
mybatis沒有hibernate那么強大,但是mybatis最大的優點就是簡單小巧易于上手,方便瀏覽修改sql語句。
Mybatis框架認知
是別人開發的一種半成品軟件,可以用來通過定制輔助快速開發是工具.
1.mybatis入門簡介
java程序都是通過jdbc連接數據庫的,
jdbc連接數據庫分為這幾步:
.注冊驅動,連接數據庫和數據庫信息.
.操作connection,打開statement對象.
.通過statement執行sql語句,返回結果到resultset對象
.使用resultset對象讀取數據,然后通過代碼轉換為具體的POJO對象(普通的java對象)
.關閉數據庫相關資源.
缺點:
工作量大,造成的廢管代碼多,還需要對異常進行捕捉處理.
由于jdbc存在的缺陷,于是提出了對象關系映射(ORM Object Relational Mapping),ORM模型就是數據庫的表和POJO對象的相互映射.
java ———>映射 —–>數據
程序《——– 配置《——庫
Hibernate框架,就是基礎ORM模型進行搭建的.他是一個全自動映射框架,與此相比.
mybatis框架,是一個半自動框架mybatis框架.優化了Hibernate框架的缺點.
Hibernate框架缺點:
.全表映射帶來的不便,比如更新是需要發送所有字段.
.無法根據不同的條件組裝不同的sql.
.對多表關聯和復雜sql查詢支持較差,需要自己寫sql,返回后,需要自己將數據組裝成POJO.
.不能有效支持存儲過程.
.雖有HQL,但是性能較差,大型互聯網系統往往需要優化sql.而Hibernate做不到.
mybatis和hibernate是基于持久層的開發框架.
mybatis所需要的映射文件包含三部分:
SQL
映射規則
POJO
mybatis《—- pojo—->注解 SQL_Mapper —->數據
應用程序—->對象《—- 接口 xml映射文件 《—-庫
mybatis的基本構成
.SqlSessionFactoryBuilder(構造器):他會根據配置信息或者代碼來生成SqlSessionFactory(工廠接口).
.SqlSessionFactory:依靠工廠來生成SqlSession(會話).
.SqlSession:是一個既可以發送SQL去執行并返回結果,也可以獲取Mapper接口.
.Sql Mapper:他是MyBatis新設計的組件,他是由一個java接口和xml文件(或者注解)構成的.需要給出對應的SQL和映射規則,
他負責發送SQL去執行,并返回執行結果.
簡單的mybatis使用
首先將下載mybatis包,將eclipse包放入myeclipse底下dropins中.然后將generator.xml放入你的項目中將數據庫配置、項目配置等更改完畢.
在generator.xml文件上點擊右鍵,生成dao層、實體類和mapper映射文件.
設計并創建對應的表結構
編程調用映射文件中的sql語句進行數據的insert操作
// 通過工具類Resouces獲取讀取核心配置文件的輸入流
InputStream is = Resources.getResourceAsStream(“mybatis-config.xml”);
// 通過SqlSessionFactory的構建器解析讀取核心配置文件,并創建SqlSessionFactory對象
SqlSessionFactory fac = new SqlSessionFactoryBuilder().build(is);
// 獲取SqlSession對象,這個對象一般充當實體管理器的功能,提供了一般的CRUD的方法
SqlSession session = fac.openSession();
StudentBean sb1 = new StudentBean();
sb1.setName(“張三”);
sb1.setBirth(new java.sql.Date(89, 2, 3));
sb1.setSex(false);
// 通過sqlSession對象調用映射元文件中的《insert>定義執行數據的插入操作,參數1為《insert>的名稱
int len = session.insert(“com.yan.entity.StudentBean.insert”, sb1);// 返回值為所執行的SQL語句的受影響行數
//mybatis框架默認采用事務回滾,如果需要修改生效,則必須進行手動提交處理
session.commit();
session.close();
評論
查看更多