我被一项简单的任务困住了。 我只需要安排这次通话的结果
$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
实际上,您可以在查询中执行此操作。
$results = Project::orderBy('name')->get();
这将以适当的顺序返回所有结果。
注意,你可以这样做:
$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::latest('created_at')->get();
2017年更新
Laravel 5.4在查询生成器中添加了orderByDesc()方法:
$results = Project::orderByDesc('name')->get();