我被一项简单的任务困住了。 我只需要安排这次通话的结果
$results = Project::all();
其中Project是一个模型。我试过了
$results = Project::all()->orderBy("name");
但这并没有起作用。从表中获取所有数据并对其进行排序的更好方法是什么?
我被一项简单的任务困住了。 我只需要安排这次通话的结果
$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();
其他回答
如果您仍然想使用all(),您仍然可以使用sortBy(在集合级别)而不是orderBy(在查询级别),因为它返回一个对象集合。
升序排序
$results = Project::all()->sortBy("name");
降序排列
$results = Project::all()->sortByDesc("name");
请查看关于集合的文档以获得更多详细信息。
https://laravel.com/docs/5.1/collections
此外,为了支持前一种答案,还可以将其作为第二个参数添加,从而按降序desc或升序asc进行排序。
$results = Project::orderBy('created_at', 'desc')->get();
一个有趣的事情是多重顺序:
根据laravel文档:
DB::table('users')
->orderBy('priority', 'desc')
->orderBy('email', 'asc')
->get();
这意味着laravel将根据优先级属性对结果进行排序。当它完成时,它将根据内部电子邮件以相同的优先级排序结果。
编辑:
正如@HedayatullahSarwary所说,推荐使用Eloquent而不是QueryBuilder。当然,我不鼓励使用QueryBuilder,我们都知道每个都有自己的用例。
无论如何,为什么我用QueryBuilder写了一个答案?正如我们在雄辩的文献中看到的:
您可以将每个Eloquent模型看作一个强大的查询构建器,允许您流畅地查询与模型关联的数据库表。
BTWS上面带有eloquent的代码应该是这样的:
Project::orderBy('priority', 'desc')
->orderBy('email', 'asc')
->get();
这样做:
$results = Project::orderBy('name')->get();
为什么? 因为它很快!排序在数据库中完成。
不要这样做:
$results = Project::all()->sortBy('name');
为什么? 因为它很慢。首先,这些行从数据库中加载,然后加载到Laravel的Collection类中,最后在内存中排序。
你的指示需要打电话去取,因为它要带记录和目录
$results = Project::orderBy('name')
->get();
例子:
$results = Result::where ('id', '>=', '20')
->orderBy('id', 'desc')
->get();
在本例中,根据“where”对数据进行过滤,并根据从高到低的顺序带来大于20的记录和orderBy目录。