为了处理大型数据库,laravel 提供了 chunk 方法,如下所示 https://laravel.com/docs/5.1/queries#retrieving-results
但是如何在这个查询中使用 chunk 方法,
$data = Inspector::latest('id')
->select('id', 'firstname', 'status', 'state', 'phone')
->where('firstname', 'LIKE', '%' . $searchtext . '%')
->get();
我要像这样返回 json 响应,
echo json_encode($data);
任何建议....
最佳答案
据我了解,chunk()
方法适用于需要处理大型数据集并逐 block 对该数据采取操作的情况。
从你的问题来看,听起来你正在执行一个查询然后将数据作为 JSON 返回给我,这听起来不像你正在对需要分块的数据集执行操作。
如果您想分解返回的 JSON 数据,您应该查看 pagination .
您可以像这样对您的查询应用分页:
$data = Inspector::latest('id')
->select('id', 'firstname', 'status', 'state', 'phone')
->where('firstname', 'LIKE', '%' . $searchtext . '%')
->paginate();
您可以通过将数字传递给分页方法来指定每个集合的大小:
$data = Inspector::latest('id')
->select('id', 'firstname', 'status', 'state', 'phone')
->where('firstname', 'LIKE', '%' . $searchtext . '%')
->paginate(25);
如果我误解了你确实想要进行分块,我相信你可以执行以下操作:
$data = Inspector::latest('id')
->select('id', 'firstname', 'status', 'state', 'phone')
->where('firstname', 'LIKE', '%' . $searchtext . '%')
->chunk(50, function($inspectors) {
foreach ($inspectors as $inspector) {
// apply some action to the chunked results here
}
});
此外,如果您要返回一个 Eloquent 对象,它将自动转换为 json,因此据我所知您不需要执行 json_encode()
。
编辑
如果我完全误解了你而你真正想做的是这样的:
{ 1000 records } -> this is the result of your query
拆分成这样:
{
{ 300 records},
{ 300 records},
{ 300 records},
{ 100 records},
}
然后你需要Collection
的 block 方法:
$data = Inspector::latest('id')
->select('id', 'firstname', 'status', 'state', 'phone')
->where('firstname', 'LIKE', '%' . $searchtext . '%')
->get() // now we're working with a collection
->chunk(300);
请记住,在您获得查询结果之前,您不会使用Collection
,因此如果您只是调用chunk()
,它将期待一个回调,它将应用于整个数据集,因为您正在使用 Eloquent
。
有关 Collection
chunk()
方法的进一步阅读,请参见此处:https://laravel.com/docs/5.3/collections#method-chunk
否则...您能否为您实际做的事情提供更多背景信息?听起来您确实需要分页。你在用 JSON 数据做什么,你是如何调用 HTTP 请求的,是通过 ajax 吗?为什么一次需要全部 1000 条记录?
如果您确实需要将 1000 个数据集发送给客户端,但一次发送 300 个数据集,那么您不想使用 block 。想一想 chunk()
在 eloquent 上下文中的作用,它不是让 block 一次返回给客户端一个 block ,直到它拥有整个数据集 - 它是为了应用一个 Action 到一个 block 然后返回整个集合,使用它的目的是这样它不会通过加载整个集合来处理操作而一次占用太多内存。
如果您想要一点一点地获取整个数据集,而分页不适用于您的情况(我还没明白为什么!),您将需要多次调用 HTTP 请求以一点一点地获取数据,并且在每个请求中指定您已经拥有的和需要的。
关于php - 使用 Eloquent 的 Laravel block 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39972653/