04-MyBaits辅助功能

本文详细介绍了MyBatis的延迟加载机制,强调了其在减少不必要的数据库查询中的作用。同时,讨论了一级缓存和二级缓存的工作原理、开启条件,以及在优化查询速度和降低服务器压力方面的重要性。此外,还涵盖了动态SQL的使用,包括SQL片段、if、where、trim、choose、when、otherwise和foreach等元素的应用,以及批量操作和Lombok的相关知识。
摘要由CSDN通过智能技术生成

延迟加载(按需加载)

在查询时,某个对象有关联对象。如果只要主对象的值,暂不需要关联对象的值

此时我们就可开启延迟加载,如不开启延迟加载,虽然你不要关联对象的数据,但是MyBatis还是会做查询

注意:延迟加载只在分步情况下有效

开启方式一

全局开启

 <setting name="lazyLoadingEnabled" value="true"/>

开启方式二

局部开启(association collection 上开启)

fetchType:lazy -- 开启延迟加载 / eager -- 关闭延迟加载
<association property="category" javaType="category" column="cid"  select="getCatByCid" fetchType="lazy"></association>

MyBaits的缓存

作用

  1. 减小服务器压力

  2. 提高查询速度

一级缓存(sqlSession级别)

同个sqlSession中,若多次请求相同数据,后面数据请求可来自缓存(一级缓存默认开启)

public static void main(String[] args) throws IOException {
    SqlSession session = new MyBatisUtil().getSqlSession();
    GoodsDao goods = session.getMapper(GoodsDao.class);
    // 首次加载
    List<Goods> selgoods = goods.selGoods();
    for (Goods g : selgoods) {
        System.out.println(g.getPName());
    }
    // 清除缓存(每次调用只执行1次) -- 一级缓存(默认在关闭sqlSession时清除)
    // 清除数据:将重新查询后加载数据
    // 不清除缓存:直接调用相同查询缓存结果,无需重新查询数据
    session.clearCache();
    // 二次加载相同数据
    List<Goods> selgoods2 = goods.selGood
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值