我想检索插入到表中的最后一个文件。我知道方法first()存在,并为您提供表中的第一个文件,但我不知道如何获得最后一个插入。
当前回答
获取最后的记录细节
模型::所有()- > ();或 模型:orderBy(“id”,desc) - > ();
获取最后一个记录id
模型::所有去年()()- > - > id;或 模型:orderBy(“id”,desc) - >第()- > id;
其他回答
你从来没有提到你是否使用Eloquent, Laravel的默认ORM。如果你是,让我们假设你想要获得一个User表的最新条目,通过created_at,你可能会这样做:
User::orderBy('created_at', 'desc')->first();
首先,它根据created_at字段逐级排序用户,然后获取结果的第一条记录。
这将返回User对象的一个实例,而不是一个集合。当然,为了使用这个替代方案,您必须有一个User模型,扩展Eloquent类。这听起来可能有点令人困惑,但它真的很容易开始,ORM真的很有帮助。
要了解更多信息,请查看官方文档,它非常丰富和详细。
对于拉拉维尔 8:
Model::orderBy('id', 'desc')->withTrashed()->take(1)->first()->id
结果的sql查询:
Model::orderBy('id', 'desc')->withTrashed()->take(1)->toSql()
从“时间表”中选择*按“id”排序
你只需要检索数据并反转它们,你就会得到你想要的记录,让我解释laravel 9的代码
return DB::table('files')->orderBy('upload_time', 'desc')->first();
如果你不愿意。x的最后结果
return DB::table('files')->orderBy('upload_time', 'desc')->limit(x)->get();
使用Laravel提供的最新范围开箱即用。
Model::latest()->first();
这样就不用检索所有的记录了。orderBy的一个更好的快捷方式。
您将需要按照您现在正在排序的相同字段进行排序,但是降序。 举个例子,如果你有一个名为upload_time的上传时间戳,你可以这样做;
Pre-Laravel 4
return DB::table('files')->order_by('upload_time', 'desc')->first();
Laravel 4及以上版本
return DB::table('files')->orderBy('upload_time', 'desc')->first();
适用于Laravel 5.7及以上版本
return DB::table('files')->latest('upload_time')->first();
这将按上传时间、降序对文件表中的行进行排序,并选择第一个。这将是最新上传的文件。
推荐文章
- Laravel未知列'updated_at'
- 如何评论laravel .env文件?
- Laravel -创建模型,控制器和迁移在单一的工匠命令
- 如何使用Laravel迁移将时间戳列的默认值设置为当前时间戳?
- 选择“表”中的“最后一行”
- Laravel:获取基本URL
- 迁移:不能添加外键约束
- Visual Studio代码PHP Intelephense保持显示不必要的错误
- 如何在laravel雄辩中选择具体的栏目
- PSR-0和PSR-4有什么区别?
- 在Laravel安全地移除迁移
- Laravel 4:如何使用雄辩的ORM进行“排序”
- 禁用Laravel的雄辩时间戳
- 如何在PATH中放置~/.composer/vendor/bin目录?
- 添加自定义属性Laravel / Eloquent模型加载?