首页 > 解决方案 > Laravel 按时间获取数据

问题描述

我需要获取从 10 分钟前到现在创建的数据,但它返回错误的结果

$defs = OrderDefaultProgress::where('name', 'Laundry Mencari supir')->pluck('id')->toArray();
$progresses = OrderProgress::where('created_at', '<=', Carbon::now()->subMinutes(10))->whereIn('progress_id', $defs)->get();

$progresses返回时间戳2021-02-07T09:15:44.000000Z为 8 小时前的数据。

[
    {
        "id": "7ce3bd58-3f19-4de9-8b92-e196d6e7b97f",
        "order_id": "175fe9ed-6932-4d5e-ba8f-ec36acf7d872",
        "progress_id": "b816f3bf-9c58-4e77-8d67-b834cac4ae77",
        "created_at": "2021-02-07T09:15:44.000000Z",
        "updated_at": "2021-02-07T09:15:44.000000Z"
    }
]

奇怪的是,在我的数据库中我什至没有这样的时间戳!

一

标签: phplaravel

解决方案


不要在这里使用 from 'where',使用 from whereBetweeninested 之where类的:

OrderProgress::whereBetween('created_at', [Carbon::now()->subMinutes(10), Carbon::now()])->whereIn('progress_id', $defs)->get();

我希望这对你有用。


推荐阅读