通过 Laravel 的 orderBy 关系按顺序检索相关模型记录
在 Laravel 中,从相关模型访问数据时,可以对使用 orderBy 方法的结果。例如,以下代码检索作者的所有评论并将其显示在列表中:
foreach($post->user->comments as $comment) { echo "<li>" . $comment->title . " (" . $comment->post->id . ")</li>"; }
但是,该列表可能未按所需顺序排序。要根据帖子 ID 对结果进行排序,您可以使用查询函数扩展关系:
public function comments() { return $this->hasMany('Comment')->orderBy('column'); }
'column' 参数指定要排序的列。
为了更加灵活,您可以允许用户通过控制器方法指定 orderBy 列:
public function comments() { return $this->hasMany('Comment'); } class Controller { public function index() { $column = Input::get('orderBy', 'defaultColumn'); $comments = User::find(1)->comments()->orderBy($column)->get(); // use $comments in the template } }
该方法提供了基于用户输入的相关模型记录的动态排序,从而使结果的显示具有更大的灵活性.
以上是如何使用 Laravel 的'orderBy”关系来排序相关模型记录?的详细内容。更多信息请关注PHP中文网其他相关文章!