Mybatis学习笔记(3)之高级功能

本文详细介绍了Mybatis的高级功能,包括一对一、一对多、多对多映射的resultType与resultMap方法,以及延迟加载和查询缓存的使用。在映射关系部分,讲解了如何通过resultMap处理复杂关联。在缓存方面,阐述了一级缓存和二级缓存的工作原理,并展示了如何开启和配置二级缓存,以及Mybatis与Ehcache的整合。最后提到了Spring与Mybatis的整合方法。
摘要由CSDN通过智能技术生成

高级功能

映射关系

一对一映射

SQL语句:用户订单查询

SELECT

 orders.*,

  USER.username,

 USER.sex,

 USER.address

FROM

 orders,

 USER

WHERE orders.user_id = user.id

resultType方法

1.        定义pojo对象

由于原始的Orders.java不能映射全部字段,所以需要新创建的pojo。如下:


2.        在mapper.xml相应的sql语句配置中,输出类型为上边定义的pojo对象。其他照旧。


resultMap

1.        思路:

1)        使用resultMap将查询结果中的订单信息映射到Orders对象中。

2)        在orders类中添加User属性,将关联查询出来的用户信息映射到orders对象中的user属性中。

2.        方法:

1)        在主表对应类中添加关联表对应的对象


2)        在mapper.xml中定义resultMap


3)        Sql语句的配置


一对多映射

Sql语句:用户订单及订单明细

SELECT

 orders.*,

 USER.username,

 USER.sex,

 USER.address,

  orderdetail.idorderdetail_id,

 orderdetail.items_id,

 orderdetail.items_num,

 orderdetail.orders_id

FROM

 orders,

 USER,

 orderdetail

WHERE orders.user_id = user.id ANDorderdetail.orders_id=orders.id

resultMap方法

1.        主表对应实体类中添加属性:在orders.java类中添加List<orderDetail> orderDetails属性。最终会将订单信息映射到orders中,订单所对应的订单明细映射到orders中的orderDetails属性中

2.        定义

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值