dtzh131555 2017-04-06 14:44
浏览 105
已采纳

为什么求和大数据不起作用? (Laravel 5.3)

My code, you can see this below :

public function total()
{
    $query = User::limit(100000)->get();
    $total = $query->sum('total');
    dd($total);
}

The result of dd($total) not display or empty

But when I change limit(50000), it display the result

Why it does not work if limit(100000)?

Note :

In firefox browser, it does not display anything

In chrome browser, it display error :

This page isn’t working

myshop.dev is currently unable to handle this request. HTTP ERROR 500

  • 写回答

1条回答 默认 最新

  • dongxiaoguang9108 2017-04-06 14:51
    关注

    When you call get, you are fetching all this records from the database. And then performing the sum with php. You are probably having a timeout when fetching that much records from the database.

    Why don't you perform the sum in the database, and then fetch the result?

    public function total()
    {
        $total = User::limit(100000)->sum('total');
        dd($total);
    }
    

    ----- edit -----

    When you perform:

    $query = User::limit(100000)->get();

    The $query variable actually holds the result set of the query select * from user limit 100000. The result set its a collection (see collect), then you are performing a sum on the server-side, something equivalent to:

    $sum = 0;
    foreach ($user in $query) {
        $sum = $sum + $user->total;
    }
    

    It's better to perform the sum in the database using the proper aggregate function.

    $total = User::limit(100000)->sum('total'); would translate to:

    select SUM(total) from user limit 1000000

    If the result is 0, probably all your result set for the column total is actually 0.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料