![公司內(nèi)部培訓mybatis3課件_第1頁](http://file4.renrendoc.com/view/9ba9ec8dba0ab7477bb2613d70531bbf/9ba9ec8dba0ab7477bb2613d70531bbf1.gif)
![公司內(nèi)部培訓mybatis3課件_第2頁](http://file4.renrendoc.com/view/9ba9ec8dba0ab7477bb2613d70531bbf/9ba9ec8dba0ab7477bb2613d70531bbf2.gif)
![公司內(nèi)部培訓mybatis3課件_第3頁](http://file4.renrendoc.com/view/9ba9ec8dba0ab7477bb2613d70531bbf/9ba9ec8dba0ab7477bb2613d70531bbf3.gif)
![公司內(nèi)部培訓mybatis3課件_第4頁](http://file4.renrendoc.com/view/9ba9ec8dba0ab7477bb2613d70531bbf/9ba9ec8dba0ab7477bb2613d70531bbf4.gif)
![公司內(nèi)部培訓mybatis3課件_第5頁](http://file4.renrendoc.com/view/9ba9ec8dba0ab7477bb2613d70531bbf/9ba9ec8dba0ab7477bb2613d70531bbf5.gif)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領
文檔簡介
1、MyBatisMyBatis 是支持普通 SQL查詢,存儲過程等一個輕量級的ORM中間件 。一、myBatis框架概述與傳統(tǒng)的 JDBC 開發(fā)相比, MyBatis 消除了幾乎所有的代碼和參數(shù)的手工設置。MyBatis 使用簡單的 XML 或注解方式,用于配置和原始映射,將接口和 Java 的POJOs(Plan Old Java Objects,普通的 Java對象)映射成數(shù)據(jù)庫中的記錄。 二、mybatis 與 hibernate 比較Hibernate基本上可以自動生成。其對數(shù)據(jù)庫結(jié)構(gòu)提供了較為完整的封裝 開發(fā)效率上, 如果使用純面向?qū)ο蠓绞紿ibernate 比較快,但如果以HQL其他
2、方式相差不多??删S護性方面, mybatis框架是以sql的開發(fā)方式,可以進行細粒度的優(yōu)化 。Hibernate自動生成的sql效果不理想。三、Mybatis開始3.1 SqlSessionFactory String resource = org/mybatis/example/Configuration.xml; Reader reader = Resources.getResourceAsReader(resource); SqlSessionFactory factory = sqlSessionFactoryBuilder.build(reader, props); 3.2 調(diào)用sq
3、lSqlSession session = sqlMapper.openSession(); try Blog blog = (Blog) session.selectOne( selectBlog, 101); finally session.close(); 3.3Mybatis的文件組成1 Configuration.xml2 Mapper.xml1 Configuration.xml系統(tǒng)的核心設置,包含獲取數(shù)據(jù)庫連接實例的數(shù)據(jù)源和決定事務范圍和控制的事務管理器1.1 Configuration.xml簡單的示例1.1.1 配置數(shù)據(jù)源 1.1.2告訴MyBatis到哪里去找相關映射文件
4、/ Using url fully qualified paths 2 Mapper.xml定義具體SQL映射語句的文件2.1 Mapper.xml簡單的示例 SELECT * FROM PERSON WHERE ID = #id 2.2 輸入屬性參數(shù)parameterType 將會傳入這條語句的參數(shù)類的完全限定名或別名。 2.3 輸出屬性參數(shù)resultType或resultMap,但不能同時使用resultType 從這條語句中返回的期望類型的類的完全限定名或別名。注意集合情形,那應該是集合可以包含的類型,而不能是集合本身。resultMap 命名引用外部的resultMap。返回map是
5、MyBatis最具力量的特性,對其有一個很好的理解的話,許多復雜映射的情形就能被解決了。2.4 resultMap 2.5 使用上的區(qū)別resultType select id, username, hashedPassword from some_table where id = #id select user_id as “id”, user_name as “”, from some_table where id = #id resultMap 引用它的語句使用resultMap屬性就行了(注意我們?nèi)サ袅藃esultType屬性)。比如: select user_id,
6、 user_name, hashed_password from some_table where id = #id 2.6 resultMap一對一、多對一 resultMap一對多 2.6 其他 delete id=insertAuthor arameterType=domain.blog.Author flushCache=true statementType=PREPARED 2.7可重用的SQL代碼段 id,username,password 這個SQL片段可以被包含在其他語句中,例如: select from some_table where id = #id 2.8 動態(tài)SQL
7、MyBatis的一個強大的特性之一通常是它的動態(tài)SQL能力。如果你有使用JDBC或其他相似框架的經(jīng)驗,你就明白條件地串聯(lián)SQL字符串在一起是多么的痛苦,確保不能忘了空格或在列表的最后省略逗號。動態(tài)SQL可以徹底處理這種痛苦。 通常使用動態(tài)SQL不可能是獨立的一部分,MyBatis當然使用一種強大的動態(tài)SQL語言來改進這種情形,這種語言可以被用在任意映射的SQL語句中。 例子 SELECT * FROM BLOG WHERE state = ACTIVE AND title like #title 處理了一個臭名昭著的動態(tài)SQL問題 state = #state AND title like #
8、title AND title like # 四 緩存機制Mapper.xml單獨配置 select*fromUSER 使用其他緩存機制五 事務機制SqlSessionFactory SqlSessionFactory有六個方法可以用來創(chuàng)建SqlSession實例。通常來說,如何決定是你選擇下面這些方法時: SqlSession openSession(ExecutorType execType) SqlSession openSession(ExecutorType execType, boolean autoCommit) SqlSession openSession
9、(ExecutorType execType, Connection connection) Configuration getConfiguration(); 默認的openSession()方法沒有參數(shù),它會創(chuàng)建有如下特性的SqlSession: 會開啟一個事務(也就是不自動提交) 連接對象會從由活動環(huán)境配置的數(shù)據(jù)源實例中得到。 事務隔離級別將會使用驅(qū)動或數(shù)據(jù)源的默認設置。 預處理語句不會被復用,也不會批量處理更新。 這些方法大都可以自我解釋的。開啟自動提交,傳遞“true”給可選的autoCommit參數(shù)。提供自定義的連接,傳遞一個Connection實例給connection參數(shù)。注意沒有覆蓋同時設置Connection和autoCommit兩者的方法,因為MyBatis會使用當前connection對象提供的設置。MyBatis
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 部編初中歷史八下第1課中華人民共和國成立教案
- 2025年全球及中國大型不銹鋼鑄件行業(yè)頭部企業(yè)市場占有率及排名調(diào)研報告
- 2025-2030全球化妝品級枯草菌脂肽鈉行業(yè)調(diào)研及趨勢分析報告
- 2025-2030全球光纖導管靜脈激光治療行業(yè)調(diào)研及趨勢分析報告
- 2025年全球及中國銅纜高速連接器行業(yè)頭部企業(yè)市場占有率及排名調(diào)研報告
- 2025國際(非獨占)商標使用許可合同
- 2025農(nóng)業(yè)種植生產(chǎn)產(chǎn)銷合同書
- 餐飲業(yè)合同年
- 2025室內(nèi)裝修設計合同范本
- 房屋租賃續(xù)簽合同模板
- 2025年湖南高速鐵路職業(yè)技術學院高職單招高職單招英語2016-2024歷年頻考點試題含答案解析
- 醫(yī)保政策與健康管理培訓計劃
- 策略與博弈杜塔中文版
- 無人化農(nóng)場項目可行性研究報告
- 2024屆上海市金山區(qū)高三下學期二模英語試題(原卷版)
- 學生春節(jié)安全教育
- 2024-2025年校長在教研組長和備課組長會議上講話
- 2025屆江蘇省常州市高級中學高三第二次模擬考試語文試卷含解析
- 高三日語一輪復習助詞「で」的用法課件
- 2024-2030年中國銣銫及其化合物行業(yè)深度調(diào)研及投資戰(zhàn)略分析報告
- 散貨物流行業(yè)市場調(diào)研分析報告
評論
0/150
提交評論