我被一项简单的任务困住了。 我只需要安排这次通话的结果

$results = Project::all();

其中Project是一个模型。我试过了

$results = Project::all()->orderBy("name");

但这并没有起作用。从表中获取所有数据并对其进行排序的更好方法是什么?


当前回答

在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();

其他回答

查看Eloquent的sortBy方法:http://laravel.com/docs/eloquent

这样做:

$results = Project::orderBy('name')->get();

为什么? 因为它很快!排序在数据库中完成。

不要这样做:

$results = Project::all()->sortBy('name');

为什么? 因为它很慢。首先,这些行从数据库中加载,然后加载到Laravel的Collection类中,最后在内存中排序。

如果您仍然想使用all(),您仍然可以使用sortBy(在集合级别)而不是orderBy(在查询级别),因为它返回一个对象集合。

升序排序

$results = Project::all()->sortBy("name");

降序排列

$results = Project::all()->sortByDesc("name");

请查看关于集合的文档以获得更多详细信息。

https://laravel.com/docs/5.1/collections

2017年更新


Laravel 5.4在查询生成器中添加了orderByDesc()方法:

$results = Project::orderByDesc('name')->get();

你的指示需要打电话去取,因为它要带记录和目录

$results = Project::orderBy('name')
           ->get();

例子:

$results = Result::where ('id', '>=', '20')
->orderBy('id', 'desc')
->get();

在本例中,根据“where”对数据进行过滤,并根据从高到低的顺序带来大于20的记录和orderBy目录。