我么都知道Hibernate的关联对象查询、级联删除、级联保存等特性,那么iBATIS是否提供同样的功能呢?这是大部分人会关心的内容。
答案也许是另人失望的。iBATIS可以关联查询,却没有提供级联保存和级联删除的特性。
关联查询
iBatis为我们提供了两种方式关联查询,第一种N+1次查询,第二种新支持的查询方式。两种方式需要根据具体的应用环境,作出合适的选择。前一种由于多了一次和数据库的读取操作,所以读取速度慢了些,但是可以使用延迟加载减少内存的消耗。而后一种方式多了些内存消耗,但是读取速度要快了。
定义一个需求:我们在查询订单的同时希望查询出其关联的订单项。
-
采用N+1次查询
-
首先看看我们的SQL Mapped配置文件如何配置的:
我们可以看到,RESULT的select属性指向一个新的查询语句。
说明:这个很好的解决了关联查询的问题,而且如果我们配置了全局的延迟加载,当真正用到订单项的时候,iBatis才为我们做查询的动作。
但是这却带来了另外一个问题,N+1次查询的问题。也就是多了一次数据库的读操作,有一定的性能损失。
-
新查询方式
-
首先看看我们的SQL Mapped配置文件如何配置的:
-
我们可以看到,RESULT的resultMap属性指向一个resultMap标签定义。
说明:与前面N+1次查询方式比较,由于只读取数据库一次,的确读取速度更快了,但是由于存在更多的内存消耗(N+1方式可以通过延迟加载来减少内存的消耗),所以我们该根据具体的应用情况而选择合适的方式。