使用MyBatis in查询(单次查询)和for循环查询(多次查询) 的效率问题

4 篇文章 0 订阅

两种查询如下

  • in查询
    List<Person> personList 
    		= this.list(Wrappers.<Person>lambdaQuery().in(Person::getId, ids));
    
  • for查询
    for(String id : ids){
    	Person = this.selectById(id);
    }
    

很多人都会思考这两者的效率问题,但可能没什么头绪

首先大家应该是看到:“in查询效率低” 这种说法,就认为所有的in查询效率都低,一旦使用到in时就会有所疑虑。实际上这种说法说的是in中嵌套子查询语句的情况,确实有这么一回事,但本文不做讨论,因为实际的开发中"关联表查询影响效率的问题"是可以在设计上避免的,而且也应该在设计上避免。

那么就只对上述代码例子中的情况进行分析,in语句中不包含子查询,而是确切的一些值。在这种情况下,要分析的效率问题是:网络传输

  • for查询:需要循环交互数据库,即便有连接池复用(连接池会复用connection,避免多次创建和关闭connection造成时间浪费),但每次的网络传输还是会拖慢总体的速度 (做过代码执行效率分析的都知道,程序本身的运行其实并不会消耗多少时间,反而是网络传输消耗的时间较多)
  • in查询:相比for查询,in查询将多次交互直接降为一次,只进行一次网络传输,节省了网络传输的时间。

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
MyBatis中,可以使用foreach标签来实现循环操作。根据提供的引用内容,我们可以看到一个foreach标签的示例。在这个例子中,通过将一个List集合传递给foreach标签的collection属性,可以循环遍历集合中的每个元素,并在SQL语句中使用这些元素。例如,可以使用#{workcode}来获取每个workcode的值。这样,可以在SQL语句中正确地循环数据并执行插入操作。引用提供了一个关于如何处理包含在对象中的List集合的例子。通过将这个对象传递给SQL语句的参数,可以在循环过程中正确地插入数据。通过这种方法,可以在MyBatis使用foreach循环来解决一对多关系的插入问题。该方法可以减少网络传输次数,提高效率,因为只需要一次网络传输即可完成整个循环操作,而不是每次循环都进行一次网络传输。因此,使用MyBatis的foreach循环可以有效地处理这种情况。123 #### 引用[.reference_title] - *1* [mybatis 中for循环](https://blog.csdn.net/thedarkclouds/article/details/81384195)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *2* [Mybatis中的foreach循环——循环插入多条数据](https://blog.csdn.net/a498936289/article/details/127994634)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *3* [使用MyBatis in查询(单次查询)和for循环查询(多次查询) 的效率问题](https://blog.csdn.net/qq_43413788/article/details/107905007)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值