mybatis特性--- 级联查询

         我么都知道Hibernate的关联对象查询、级联删除、级联保存等特性,那么iBATIS是否提供同样的功能呢?这是大部分人会关心的内容。

      答案也许是另人失望的。iBATIS可以关联查询,却没有提供级联保存和级联删除的特性。

关联查询

iBatis为我们提供了两种方式关联查询,第一种N+1次查询,第二种新支持的查询方式。两种方式需要根据具体的应用环境,作出合适的选择。前一种由于多了一次和数据库的读取操作,所以读取速度慢了些,但是可以使用延迟加载减少内存的消耗。而后一种方式多了些内存消耗,但是读取速度要快了。

定义一个需求:我们在查询订单的同时希望查询出其关联的订单项。

  1. 采用N+1次查询

  2. 首先看看我们的SQL Mapped配置文件如何配置的:

    我们可以看到,RESULT的select属性指向一个新的查询语句。

     

    说明:这个很好的解决了关联查询的问题,而且如果我们配置了全局的延迟加载,当真正用到订单项的时候,iBatis才为我们做查询的动作。

    但是这却带来了另外一个问题,N+1次查询的问题。也就是多了一次数据库的读操作,有一定的性能损失。


  3. 新查询方式

  4. 首先看看我们的SQL Mapped配置文件如何配置的:


  5. 我们可以看到,RESULT的resultMap属性指向一个resultMap标签定义。

     

    说明:与前面N+1次查询方式比较,由于只读取数据库一次,的确读取速度更快了,但是由于存在更多的内存消耗(N+1方式可以通过延迟加载来减少内存的消耗),所以我们该根据具体的应用情况而选择合适的方式。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值