Laravel: orderBy를 사용하여 관계 정렬
Laravel에서 관계 작업을 수행할 때 특정 방식으로 결과를 정렬하는 것이 유용할 수 있습니다. 예를 들어, 게시물과 관련된 댓글을 시간순으로 표시하고 싶을 수 있습니다.
특정 게시물의 작성자가 게시한 모든 댓글을 반복하는 다음 루프를 고려해 보세요.
foreach($post->user->comments as $comment) { echo "<li>" . $comment->title . " (" . $comment->post->id . ")</li>"; }
이 루프는 다음과 같은 출력을 생성할 수 있습니다.
I love this post (3) This is a comment (5) This is the second Comment (3)
post_id별로 목록을 정렬하려면 다음과 같이 댓글 관계를 확장할 수 있습니다. orderBy 함수:
public function comments() { return $this->hasMany('Comment')->orderBy('column'); }
이제 주석을 반복하면 원하는 순서로 표시됩니다.
This is the second Comment (3) I love this post (3) This is a comment (5)
또는 보다 유연한 사용 방법을 사용할 수 있습니다. 입력으로 orderBy 함수를 사용하며, 입력::get() 입력 확인 예제와 유사합니다.
class User { 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 } }
전달하여 orderBy 열을 입력으로 사용하면 사용자 입력에 따라 주석을 동적으로 정렬할 수 있습니다. 보안을 위해 적절한 입력 확인을 구현하는 것을 잊지 마세요.
위 내용은 Laravel에서 Eloquent Relationship을 어떻게 주문할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!