我被一项简单的任务困住了。 我只需要安排这次通话的结果
$results = Project::all();
其中Project是一个模型。我试过了
$results = Project::all()->orderBy("name");
但这并没有起作用。从表中获取所有数据并对其进行排序的更好方法是什么?
我被一项简单的任务困住了。 我只需要安排这次通话的结果
$results = Project::all();
其中Project是一个模型。我试过了
$results = Project::all()->orderBy("name");
但这并没有起作用。从表中获取所有数据并对其进行排序的更好方法是什么?
当前回答
2017年更新
Laravel 5.4在查询生成器中添加了orderByDesc()方法:
$results = Project::orderByDesc('name')->get();
其他回答
查看Eloquent的sortBy方法:http://laravel.com/docs/eloquent
如果您仍然想使用all(),您仍然可以使用sortBy(在集合级别)而不是orderBy(在查询级别),因为它返回一个对象集合。
升序排序
$results = Project::all()->sortBy("name");
降序排列
$results = Project::all()->sortByDesc("name");
请查看关于集合的文档以获得更多详细信息。
https://laravel.com/docs/5.1/collections
在Laravel Eloquent中,你必须创建像下面这样的查询,它将从DB中获得所有数据,你的查询是不正确的:
$results = Project::all()->orderBy("name");
你必须这样使用它:
$results = Project::orderBy('name')->get();
默认情况下,您的数据是升序的,但您也可以以以下方式使用orderBy:
//---Ascending Order
$results = Project::orderBy('name', 'asc')->get();
//---Descending Order
$results = Project::orderBy('name', 'desc')->get();
而你需要的结果日期描述
$results = Project::latest('created_at')->get();
2017年更新
Laravel 5.4在查询生成器中添加了orderByDesc()方法:
$results = Project::orderByDesc('name')->get();