PHP 프레임워크 Laravel Laravel에서 연결된 테이블 데이터를 쿼리하는 방법을 설명하는 예

Laravel에서 연결된 테이블 데이터를 쿼리하는 방법을 설명하는 예

Apr 07, 2023 pm 05:02 PM

Laravel은 단순성과 우아함이 특징이며 MVC 아키텍처를 지원하는 오픈 소스 PHP 프레임워크입니다. PHP 개발자가 선호하는 도구 중 하나인 Laravel 프레임워크는 빠른 개발, 탁월한 확장성 및 탁월한 문서 지원으로 널리 호평을 받고 있습니다. 그 중에서도 라라벨의 연결 테이블 쿼리 데이터는 매우 중요한 기능이므로 아래에서 간단히 소개하겠습니다.

데이터베이스에서 서로 다른 테이블 사이에 관계가 있는 경우 이러한 관계를 기반으로 조인 쿼리를 수행하여 필요한 데이터를 얻어야 합니다. 이것이 조인 테이블 쿼리입니다. 아래에서는 예제를 사용하여 Laravel에서 연결된 테이블 데이터를 쿼리하는 방법을 알아봅니다.

  1. 두 개의 데이터 테이블 생성

해당 코드를 작성하기 전에 조인 테이블 쿼리 기능을 테스트하기 위해 먼저 두 개의 데이터 테이블을 생성해야 합니다. 여기서는 학생 테이블과 성적 테이블을 예로 들어 보겠습니다. 학생 테이블에는 학생의 학번, 이름, 반이 포함되고, 성적 테이블에는 학생 번호, 과목명, 성적이 포함됩니다. 두 개의 데이터 테이블을 생성한 후 Laravel에서 해당 모델을 설정해야 합니다.

  1. 연결된 테이블 데이터 쿼리

Laravel 쿼리 구문은 매우 간결하고 우아하며 사용하기 매우 편리합니다. Laravel을 통해 조인 테이블 쿼리를 수행하는 방법을 살펴보겠습니다.

먼저 Student 모델에서 Grade 모델과 연결되는 메서드를 정의합니다.

public function grades()
{
    return $this->hasMany('App\Grade', 'student_id', 'id');
}
로그인 후 복사

이 메서드의 기능은 Student와 Grade 모델 간의 관계를 설정하는 것입니다. hasMany는 학생이 여러 등급에 해당할 수 있음을 나타냅니다. subject 이므로 "일대다" 관계가 사용됩니다. 다음 두 매개변수는 Laravel에 해당하는 데이터베이스 필드 이름입니다. 첫 번째 매개변수는 grades 테이블에서 학생 테이블을 연결하는 데 사용되는 필드 이름을 나타내고, 두 번째 매개변수는 학생 테이블의 기본 키를 나타냅니다.

다음으로, Laravel의 쿼리 메소드를 사용하여 Student 테이블과 Grade 테이블의 데이터를 쿼리할 수 있습니다. 학생의 학생 ID, 이름, 모든 과목의 성적을 쿼리해야 한다고 가정하면 다음 코드를 작성할 수 있습니다.

$students = Student::with('grades')->get();
로그인 후 복사

이 코드는 모든 학생 정보와 해당 성적이 포함된 배열을 반환하므로 foreach 루프를 사용해야 합니다. 이 배열을 탐색하여 해당 과목에 대한 각 학생의 이름, 학생 번호 및 성적을 출력합니다.

foreach ($students as $student) {
    echo $student->id . ' - ' . $student->name . '<br>';
    foreach ($student->grades as $score) {
        echo $score->grade . ' - ' . $score->subject . '<br>';
    }
}
로그인 후 복사

이 코드는 모든 학생의 학생번호, 이름, 학년 정보를 출력합니다. 이 예제에서 볼 수 있듯이 Laravel을 사용하여 연결된 테이블의 데이터를 쿼리하는 것이 매우 편리하고 코드 크기가 매우 간결합니다.

요약

Laravel의 조인 테이블 쿼리 데이터는 매우 간단하고 우아하며 편리합니다. Laravel의 모델 연관 방법을 사용하면 서로 다른 모델 간의 관계를 쉽게 설정할 수 있습니다. 쿼리 문을 사용할 때 해당 메서드를 호출하기만 하면 쿼리 및 출력 기능을 실현할 수 있으므로 코딩의 어려움과 작업량이 크게 줄어듭니다. Laravel의 조인 테이블 쿼리 기능에 능숙하면 개발 효율성을 크게 향상시키고 개발 작업의 편의성을 높일 수 있습니다.

위 내용은 Laravel에서 연결된 테이블 데이터를 쿼리하는 방법을 설명하는 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

어느 것이 더 낫습니까, 장고 또는 라벨? 어느 것이 더 낫습니까, 장고 또는 라벨? Mar 28, 2025 am 10:41 AM

Django와 Laravel은 모두 풀 스택 프레임 워크입니다. Django는 Python 개발자 및 복잡한 비즈니스 논리에 적합한 반면 Laravel은 PHP 개발자 및 우아한 구문에 적합합니다. 1. Django는 파이썬을 기반으로하며 빠른 개발 및 높은 동시성에 적합한 "배터리 완성"철학을 따릅니다. 2. Laravel은 PHP를 기반으로하며 개발자 경험을 강조하며 중소형 프로젝트에 적합합니다.

더 나은 PHP 또는 Laravel은 무엇입니까? 더 나은 PHP 또는 Laravel은 무엇입니까? Mar 27, 2025 pm 05:31 PM

Laravel은 PHP 기반 프레임 워크이기 때문에 PHP와 Laravel은 직접 비교할 수 없습니다. 1.PHP는 소규모 프로젝트 또는 빠른 프로토 타이핑에 적합하고 간단하고 직접적이기 때문에 적합합니다. 2. Laravel은 대규모 프로젝트 또는 효율적인 개발에 적합하지만 풍부한 기능과 도구를 제공하지만 가파른 학습 곡선을 가지고 있으며 순수한 PHP만큼 좋지 않을 수 있습니다.

Laravel 및 백엔드 : 파워링 웹 응용 프로그램 논리 Laravel 및 백엔드 : 파워링 웹 응용 프로그램 논리 Apr 11, 2025 am 11:29 AM

Laravel은 백엔드 논리에서 어떻게 중요한 역할을합니까? 라우팅 시스템, eloquentorm, 인증 및 승인, 이벤트 및 청취자, 성능 최적화를 통해 백엔드 개발을 단순화하고 향상시킵니다. 1. 라우팅 시스템은 URL 구조의 정의 및 요청 처리 로직을 정의 할 수 있습니다. 2. eloquentorm은 데이터베이스 상호 작용을 단순화합니다. 3. 인증 및 인증 시스템은 사용자 관리에 편리합니다. 4. 이벤트와 리스너는 느슨하게 결합 된 코드 구조를 구현합니다. 5. 성능 최적화는 캐싱 및 대기열을 통한 응용 프로그램 효율성을 향상시킵니다.

Laravel은 프론트 엔드 또는 백엔드입니까? Laravel은 프론트 엔드 또는 백엔드입니까? Mar 27, 2025 pm 05:31 PM

laravelisabackendframeworkbuiltonphp, 디자인 된 forwebapplicationdevelopment.itfocusesonserver-sidelogic, databasemanagement, andapplicationtructure, and canbeintegratedwithfrontendechnologies likevue.jsorreactforfull-stackdevelopment.

Laravel이 왜 그렇게 인기가 있습니까? Laravel이 왜 그렇게 인기가 있습니까? Apr 02, 2025 pm 02:16 PM

Laravel의 인기에는 단순화 된 개발 프로세스, 쾌적한 개발 환경 및 풍부한 기능이 포함됩니다. 1) PHP의 유연성을 결합하여 Rubyonrails의 설계 철학을 흡수합니다. 2) 개발 효율성을 향상시키기 위해 Eloquentorm, Blade Template Engine 등과 같은 도구를 제공하십시오. 3) MVC 아키텍처 및 종속성 주입 메커니즘은 코드를보다 모듈화적이고 테스트 가능하게 만듭니다. 4) 캐싱 시스템 및 모범 사례와 같은 강력한 디버깅 도구 및 성능 최적화 방법을 제공합니다.

Laravel (PHP) vs. Python : 개발 환경 및 생태계 Laravel (PHP) vs. Python : 개발 환경 및 생태계 Apr 12, 2025 am 12:10 AM

개발 환경과 생태계에서 Laravel과 Python의 비교는 다음과 같습니다. 1. Laravel의 개발 환경은 간단하며 PHP와 작곡가 만 필요합니다. Laravelforge와 같은 풍부한 확장 패키지를 제공하지만 확장 패키지 유지 보수는시기 적절하지 않을 수 있습니다. 2. 파이썬의 개발 환경도 간단하며 파이썬과 PIP 만 필요합니다. 생태계는 거대하고 여러 분야를 다루지 만 버전 및 종속성 관리는 복잡 할 수 있습니다.

Laravel의 다양성 : 간단한 사이트에서 복잡한 시스템에 이르기까지 Laravel의 다양성 : 간단한 사이트에서 복잡한 시스템에 이르기까지 Apr 13, 2025 am 12:13 AM

Laravel Development Project는 다양한 크기와 복잡성의 요구에 맞게 유연성과 힘으로 인해 선정되었습니다. Laravel은 간단한 블로그에서 복잡한 엔터프라이즈 수준 시스템에 이르기까지 라우팅 시스템, Eloquentorm, Artisan Command Line 및 기타 기능을 제공합니다.

Laravel의 주요 기능 : 백엔드 개발 Laravel의 주요 기능 : 백엔드 개발 Apr 15, 2025 am 12:14 AM

백엔드 개발에서 Laravel의 핵심 기능에는 라우팅 시스템, eloquentorm, 마이그레이션 기능, 캐시 시스템 및 큐 시스템이 포함됩니다. 1. 라우팅 시스템은 URL 매핑을 단순화하고 코드 구성 및 유지 보수를 향상시킵니다. 2. ELOQUENTORM은 객체 지향 데이터 작업을 제공하여 개발 효율성을 향상시킵니다. 3. 마이그레이션 함수는 버전 제어를 통해 데이터베이스 구조를 관리하여 일관성을 보장합니다. 4. 캐시 시스템은 데이터베이스 쿼리를 줄이고 응답 속도를 향상시킵니다. 5. 큐 시스템은 대규모 데이터를 효과적으로 처리하고, 사용자 요청을 차단하지 않으며, 전반적인 성능을 향상시킵니다.

See all articles