MySQL whereIn 有最大限制吗?

首先我们先复盘一下出现的场景:

首先我有一张优惠券表 coupon 和一张核销表 write_off_record,在列表查询的时候是使用了分页,所有在运行的使用是没问题的,但是这里有个下载功能(目前22w多),这里就会报错内存溢出
使用场景:

coupon 表

public function reocrd()
{
    return $this->hasMany(WriteOffRecord::class);
}

write_off_record 表

public function coupon()
{
    return $this->belongsTo(Coupon::class);
}

下载

Coupon::with('reocrd')->get();

注意这里使用了模型关联一对多 with(‘reocrd’),这里就会有 , 重要的事情说三遍!

1、whereIn是否有个数限制?

mysql:in是没有限制的,但是受 max_allowed_packet 默认是4MB,大约2000个之内没问题
oracle:最多是1000个

2、如何查看 sql 语句最大限制

mysql --help | grep max-allowed-packet

解决方法:

使用 join 代替 wherein
如果有好的解决办法请赐教!

原文地址:mysql whereIn有最大限制吗?

php
本作品采用《CC 协议》,转载必须注明作者和本文链接
不要轻易放弃。学习成长的路上,我们长路漫漫,只因学无止境 Don't give up easily. On the way of learning and growing up, we have a long way to go, just because there is no end to learning.
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 4

需求是一次性全部下载完?分批下载怎么样,根据时间、用户等条件来筛选。

4年前 评论
vinhson (楼主) 4年前
sork 4年前

PDO绑定数量,是有限制的

4年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!