Mybatis collection和PageHelper共存时出现的巨坑(*/ω\*)

在使用Mybatis的PageHelper进行分页查询时,遇到数据丢失问题,原因是PageHelper通过拦截器添加limit导致一对多查询结果不全。PageHelper官方建议使用嵌套查询或自定义分页逻辑。解决方案包括使用Mybatis的嵌套查询(可能影响性能)或手动重写分页逻辑(耗时)。
摘要由CSDN通过智能技术生成

Mybatis collection和PageHelper共存时出现的巨坑

问题再现

因为公司项目中的查询功能需要,查询出来的数据是树形结构,正常情况如下:

{
   
	'data': [
		{
   
			'name': '张三',
			'IDName': '123456789',
			'......': '......',
			'status': [
				{
   
					'meetType': '0',
					'status': '0'
				},
				{
   
					'meetType': '1',
					'status': '2'
				},
				{
   
					'meetType': '2',
					'status': '1'
				},
				{
   
					'meetType': '3',
					'status': '4'
				},
				......
			]
		}
	]
}

但是使用了PageHelp分页,就出现了数据不全的问题,直接给我丢失了部分数据,导致页面上数据显示不全,使用分页后获取的数据如下(与上面的数据做对比):

{
   
	'data': [
		{
   
			'name': '张三',
			'IDName': '123456789',
			'......': '......',
			'status': [
				{
   
					'meetType': '0',
					'status': '0'
				},
				
				{
   
					'meetType': '2',
					'status': '1'
				}
			]
		}
	]
}

问题原因

对于比较了解的程序猿们都知道,PageHelper的工作原理,主要是依靠了拦截器。也就是说,在执行sql前会根据当前页数和条数在要执行的sql后面加上limit,工作原理如下:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值