MyBatis多對多的兩種處理方式
1.將一方作為成員加入多方
一次性查出
mapper.xml
<select id="findOrder" resultMap="odermap">
select orders.id, orders.user_id as userId, orders.number,
orders.createtime as createTime,orders.note,
user.username, user.birthday, user.sex, user.address, user.id as uid
from orders
left join user
on orders.user_id=user.id
</select>
<resultMap type="order" id="odermap">
<id column="id" property="id"/>
<result column="userId" property="userId"/>
<result column="number" property="number"/>
<result column="createtime" property="createTime"/>
<result column="note" property="note"/>
<association property="user" javaType="user">
<id column="uid" property="id"/>
<result column="username" property="username"/>
<result column="birthday" property="birthday"/>
<result column="sex" property="sex"/>
<result column="address" property="address"/>
</association>
</resultMap>
2.新建類繼承一方並將多方存入list
一次性查出
mapper.xml
<select id="findUserAndOrders" resultMap="findUserAndOrdersMap">
select user.*,orders.id as oid,user_id,number,createtime,note from user left join orders on user.id=orders.user_id where orders.user_id is not null </select>
<resultMap type="UserAndOrders" id="findUserAndOrdersMap">
<id column="id" property="id"/>
<result column="username" property="username"/>
<result column="birthday" property="birthday"/>
<result column="sex" property="sex"/>
<result column="address" property="address"/>
<collection property="orders" ofType="order">
<id column="id" property="id"/>
<result column="user_id" property="userId"/>
<result column="number" property="number"/>
<result column="createtime" property="createTime"/>
<result column="note" property="note"/>
</collection>
</resultMap>
分多次查出
<select id="findUserAndOrderById" resultMap="findUserAndOrdersByIdMap">
select distinct user.* from user left join orders on user.id=orders.user_id where orders.user_id is not null and user.id=#{id}
</select>
<select id="findOrder" resultType="order">
select * from orders where user_id=#{user_id}
</select>
<resultMap type="UserAndOrders" id="findUserAndOrdersByIdMap">
<id column="id" property="id"/>
<result column="username" property="username"/>
<result column="birthday" property="birthday"/>
<result column="sex" property="sex"/>
<result column="address" property="address"/>
<collection property="orders" select="findOrder" column="user_id=id" ofType="order">
</collection>
</resultMap>
相關文章
- mybatis一對多&&多對一處理MyBatis
- Mybatis一對多、多對一處理MyBatis
- #MyBatis多表查詢 #多對一、一對多的兩種實現方式 @FDDLCMyBatis
- 多對一處理 和一對多處理的處理
- 多工處理方式之一:多程式
- php 與 nginx 的兩種處理方式PHPNginx
- 多工處理方式之二:多執行緒執行緒
- MyBatis表關聯 一對多 多對一 多對多MyBatis
- mybatis的一對多,多對一,以及多對對的配置和使用MyBatis
- Mybatis【一對多、多對一、多對多】知識要點MyBatis
- 3種方式實現python多執行緒併發處理Python執行緒
- MyBatis07-(多對一、一對多)MyBatis
- 關於多執行緒的兩種實現方式執行緒
- mybatis基礎03(介面中的多個引數處理)MyBatis
- mybatis+oracle 批次插入多條資料的處理方法MyBatisOracle
- 多執行緒的建立 兩種方式以及使用建議執行緒
- 在springboot中使用Mybatis Generator的兩種方式Spring BootMyBatis
- Mybatis09_一對一、一對多、多對多、延遲載入MyBatis
- div的多種居中方式
- MyBatis中主鍵回填的兩種實現方式MyBatis
- 幀動畫的多種實現方式與效能對比動畫
- linux中cp複製時處理軟連結的兩種方式Linux
- 【java】【多執行緒】建立執行緒的兩種常用方式(2)Java執行緒
- Locust 多種執行方式
- CSS中的多種居中方式CSS
- 1117清空陣列的多種方式陣列
- JS中的多種繼承方式JS繼承
- 如何使用策略模式處理多種型別請求模式型別
- PHP處理密碼的幾種方式PHP密碼
- SQLite 併發的四種處理方式SQLite
- SpringMVC非同步處理的 5 種方式SpringMVC非同步
- Java多種寫檔案方式Java
- HTML頁面插入SVG的多種方式HTMLSVG
- 分散式鎖的多種實現方式分散式
- vue引用js檔案的多種方式VueJS
- Java異常處理的兩種方式以及自定義異常的使用方法Java
- 處理多個異常
- Spring Boot MyBatis配置多種資料庫Spring BootMyBatis資料庫
- 微核心、多執行緒、SMP對稱多處理、分散式作業系統執行緒分散式作業系統