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

$results = Project::all();

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

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

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


当前回答

试试这个:

$categories     =   Category::all()->sortByDesc("created_at");

其他回答

此外,为了支持前一种答案,还可以将其作为第二个参数添加,从而按降序desc或升序asc进行排序。

$results = Project::orderBy('created_at', 'desc')->get();

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

升序排序

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

降序排列

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

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

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

试试这个:

$categories     =   Category::all()->sortByDesc("created_at");

注意,你可以这样做:

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

这将生成如下查询:

"SELECT name FROM proyect ORDER BY 'name' ASC"

在一些应用程序中,当数据库没有优化,查询更复杂,你需要防止在完成SQL中生成ORDER BY,你可以这样做:

$result = Project::select('name')->get();
$result = $result->sortBy('name');
$result = $result->values()->all();

现在是php对结果进行排序。

这样做:

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

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

不要这样做:

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

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