> 백엔드 개발 > PHP 튜토리얼 > Laravel에서 Eloquent Relationship을 어떻게 주문할 수 있나요?

Laravel에서 Eloquent Relationship을 어떻게 주문할 수 있나요?

DDD
풀어 주다: 2024-11-24 05:02:09
원래의
535명이 탐색했습니다.

How Can I Order Eloquent Relationships in Laravel?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿