How to chunk results from a custom query with Laravel 5
11,454
Well since the query will just return an array of objects you can simply use PHP's array_chunk()
:
$result = DB::connection('mgnt')->select($query);
foreach(array_chunk($result, 200) as $orders){
foreach($orders as $order){
// a bunch of code...
}
}
Here's what chunk()
on an eloquent model does:
$results = $this->forPage($page = 1, $count)->get();
while (count($results) > 0)
{
// On each chunk result set, we will pass them to the callback and then let the
// developer take care of everything within the callback, which allows us to
// keep the memory low for spinning through large result sets for working.
call_user_func($callback, $results);
$page++;
$results = $this->forPage($page, $count)->get();
}
You could try to do something similar (although I think it should be possible to run your query all at once, but I can't help you with that...)
- Add a limit to your SQL query
LIMIT 200
- Increase the offset with every query you run. First 0, second 1 * 200, third 2 * 200
- Do that until the result is returned empty (e.g. with a while loop like above)
Author by
kritop
Updated on June 07, 2022Comments
-
kritop almost 2 years
Following up on this Question: How to chunk results from a custom query in Laravel
I try
DB::connection('mgnt')->select($query)->chunk(200, function($orders) { foreach ($orders as $order) { //a bunch of code... } });
But I get the following error:
FatalErrorException in MigrationController.php line 98: Call to a member function chunk() on array
Is chunking possible without having an appropriate Eloquent ORM Model? I try to chunk because I get a blank page (can't find any errrors in any log) if the query returns too many results.
I think right now it max 50.000 results that I can query at once. Is that maybe due to some restriction or limitation in Laravel?