




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、Chapter4多表操作*課程回顧*1MyBateis配置文件2文件詳解3動態(tài) SQL 使用*教學導航*1一對一關系2一對一方法二3一對多關系前面章節(jié)用 mybatis 能對單表進行增刪改查操作了,也能用動態(tài) SQL 書寫比較復雜的 sql 語句。但是在實際開發(fā)中,做項目不可能只是單表操作,往往會涉及到多之間的關聯(lián)操作。那么如何用 mybatis 處理多表之間的關聯(lián)操作呢?一、一對一關聯(lián)操作查詢所有訂單信息,關聯(lián)查詢下單用戶信息。注意:因為一個訂單信息只會是一個人下的訂單,所以從查詢訂單信息出發(fā)關聯(lián)查詢用戶信息為一對一查詢。如果從用戶信息出發(fā)查詢用戶下的訂單信息則為一對多查詢,因為一個用戶可以
2、下多個訂單。使用 resultType,定義訂單信息 po 類,此 po 類中包括了訂單信息和用戶信息:建表語句見 mybatis.sql 文件。創(chuàng)建 javaWeb 工程項目 MyBatisFour(省略,參見示例 one 包部分) 1、Sql 語句準備:SELECTo.*, u.username, u.addressFROMmy_orders o,user u WHERE o.user_id = u.id and=?2、創(chuàng)建 perties在類目錄 src 下面(參見前面章節(jié))3、定義 pojo:User.java(參見 MyBatisTwo 項目)Order.javar
3、esultType Po 類中應該包括上邊 sql 查詢出來的所有字段,如下:注意:OrdersCustom 類繼承 Orders 類后 OrdersCustom 類包括了 Orders 類的所有字段,只需要定義用戶的信息字段即可。4、編寫 Mapper 接口 UserMapper.javapublicerface UaweMapper public List findOrdersList(orderID) throws Exception;public class OrdersCustom extends Order private String username;/ 用戶名稱 privat
4、e String address;/ 用戶地址.省略相應get and set 方法public class Order privateeger id; privateeger userId; private String number; private Date createtime; private String note;.省略相應get and set 方法文件 UserMapper.xml5、MyBatis配置文件加載 Mapper 接口6、編寫測試類及方法OrdersTest 類:public class OrdersTest /會話工廠private SqlSesFactory
5、sqlSesFactory;/* junit 測試中方法調用時,在執(zhí)行之前初始化方法*/ Beforepublic void init() throws IOExceptionSELECTo.*,u.username,u.address FROM My_orders o, user u WHERE o.user_id = u.id and=#id/定義mybatis 全局配置文件String resource = SqlMapConfig.xml;/加載 mybatis 全局配置文件InputStreaminputStream=Resour.getResourceAsStream(resour
6、ce);/構建sqlSes的工廠sqlSesFactory=newSqlSesFactoryBuilder().build(inputStream);Testpublic void queryByAll() List list = null;SqlSessqlSes= null;try / 創(chuàng)建數(shù)據(jù)庫會話實例sqlSessqlSes= sqlSesFactory.openSes();/獲限mapper 接口實例UserMapperuserMapper=sqlSes.getMapper(UserMapper.class);/查詢訂單信息list = userMapper.findOrdersLi
7、st(3);for (OrdersCustom ordersCustom : list) System.out.prln(ordersCustom.getUsername();catch (Exception e) e.prStackTrace();finally 執(zhí)行方法觀察結果定義專門的 po 類作為輸出類型,其中定義了 sql 查詢結果集所有的字段。此方法較為簡單,企業(yè)中使用普遍。二、一對一方法二使用 resultMap,定義專門的 resultMap 用于一對一查詢結果。在 javaWeb 工程項目 MyBatisFour(增加 two package 包部分)1、Sql 語句準備:S
8、ELECT .id,o.user_id,o.number,o.createtime,o.note,u.username,u.addressFROM My_orders o JOIN user u ON u.id = o.user_id2、定義 pojo:User.java(參見本章上例)在 Order 類中加入 User 屬性,user 屬性中用于關聯(lián)查詢的用戶信息,因為訂單關聯(lián)查詢用戶是一對一關系,所以這里使用單個 User 對象息。關聯(lián)查詢的用戶信Order.javapublic class Order privateeger id; privateeger userId; private
9、 String number; private Date createtime;private String note;if (sqlSes!= null) sqlSes.close();3、編寫 Mapper 接口 UserMapper.java文件 UserMapper.xmlpublicerface UserMapper public List findOrdersList() throws Exception;private User user;.省略 get and set 方法這里 resultMap 指定 orderUserResultMapassotion:表示進行關聯(lián)查詢單條
10、property:表示關聯(lián)查詢的結果user 屬性中在 com.java.mybatis.tow.beans.Orders 的javaType:表示關聯(lián)查詢的結果類型:查詢結果的 id 列對應關聯(lián)對象的 id 屬性,這里是表示 id 是關聯(lián)查詢對象的唯一標識。:查詢結果的 username 列對應關聯(lián)對象的 username 屬性。4、MyBatis配置文件加載 Mapper 接口5、編寫測試類及方法OrdersTest 類: SELECTo.id,o.user_id,o.number,o.createtime,o.note,u.username,u.address FROM My_order
11、s o JOIN user u ON u.id = o.user_idpublic class OrdersTest /會話工廠private SqlSes/*Factory sqlSesFactory;* junit 測試中方法調用時,在執(zhí)行之前初始化方法*/ Beforepublic void init() throws IOException/定義mybatis 全局配置文件String resource = SqlMapConfig.xml;/加載 mybatis 全局配置文件InputStream inputStream = Resour.getResourceAsStream(re
12、source);/構建sqlSes的工廠sqlSesFactory=newSqlSesFactoryBuilder().build(inputStream);Testpublic void queryByAll() List list = null;SqlSestry sqlSes= null;/ 創(chuàng)建數(shù)據(jù)庫會話實例sqlSessqlSes= sqlSesFactory.openSes();/獲限mapper 接口實例UserMapper userMapper = sqlSes/查詢訂單信息.getMapper(UserMapper.class);list = userMapper.findO
13、rdersList();for (Order ordersCustom : list) System.out.prln(ordersCustom.getUser().getUsername();觀察運行結果:三、一對多關聯(lián)查詢所有用戶信息及用戶關聯(lián)的訂單信息,用戶信息和訂單信息為一對多關系。使用 resultMap 實現(xiàn)進行介紹:在 javaWeb 工程項目 MyBatisFour(增加 three package 包部分)1、Sql 語句準備:SELECT u.*, o.id, o.number,o.createtime,o.noteFROM user u LEFT JO2、定義 pojo:
14、y_orders o ON u.id = o.user_idOrder.javapublic class Order privateeger id; catch (Exception e) e.prStackTrace(); finally if (sqlSes!= null) sqlSes.close();User.java 在 User 類中加入 Listorders 屬性3、編寫 Mapper 接口 UserMapper.java文件 UserMapper.xmlpublicerface UserMapper List getUserOrderList();public claser p
15、rivateeger id;private String username;/ 用戶private String sex;/ private Date birthday;/ 生日private String address;/ 地址privaist orders;. 省略相應 get and set 方法privateeger userId; private String number; private Date createtime; private String note;.省略 get and set 方法!- -SELECTu.*, o.id,o.number,o.createtime
16、,o.noteFROMuser uLEFT JOy_orders o ON u.id = o.user_idcollection 部分定義了用戶關聯(lián)的訂單信息。表示關聯(lián)查詢結果集property=orders:關聯(lián)查詢的結果集在 User 對象的上哪個屬性。ofType=order:指定關聯(lián)查詢的結果集中的對象類型即 List 中的對象類型。此處可以使用別名,也可以使用全名。4、MyBatis配置文件加載 Mapper 接口6、編寫測試類及方法OrdersTest 類:(跟本章上例不同部分列出)public void queryByAll() List list = null; SqlSessqlSes= null; try sqlSes= sqlSesFactory.openSes(); UserMapper userMapper =sqlSes.getMapper(UserMapper.class); list = userMapper.getUserOrderList(); for (User userOrders : list) Sy
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- DB32/T 4000-2021牛結核病診斷技術(γ-干擾素體外ELISA法)
- DB32/T 3931-2020芋頭大棚種植技術規(guī)程
- DB32/T 3820-2020公路橋梁鋼箱梁預防養(yǎng)護規(guī)范
- DB31/T 1349-2022機關會議服務管理規(guī)范
- DB31/T 1169-2019知識產(chǎn)權評議技術導則
- DB31/T 1142-2019燃氣工業(yè)鍋爐能效在線監(jiān)測技術規(guī)范
- DB31/T 1124-2018電梯應急處置公共服務平臺功能要求
- 硬件設計中的節(jié)能技術與綠色標準考核試卷
- 2024年可降解聚烯烴專用料項目資金申請報告代可行性研究報告
- 2025年中國壁掛式浴室柜行業(yè)市場前景預測及投資價值評估分析報告
- GB/T 12359-1990梯形螺紋極限尺寸
- 領退轉款賬戶確認書
- 精益生產(chǎn)精管理培訓課件
- 監(jiān)理大綱(綜合)
- 第6章職業(yè)腫瘤和職業(yè)性傳染病課件
- 陜西省漢中市各縣區(qū)鄉(xiāng)鎮(zhèn)行政村村莊村名居民村民委員會明細
- FIDIC銀皮書(中英文對照)
- 癲癇護理查房.ppt課件
- 軍事地形學地形圖基本知識
- 固體火箭發(fā)動機制造工藝
- 試卷密封線模板
評論
0/150
提交評論