PHP 프레임워크 Laravel Laravel 개발: 데이터베이스 쿼리에 Eloquent ORM을 사용하는 방법은 무엇입니까?

Laravel 개발: 데이터베이스 쿼리에 Eloquent ORM을 사용하는 방법은 무엇입니까?

Jun 14, 2023 pm 12:47 PM
laravel 데이터베이스 쿼리 eloquent orm

Laravel은 웹 애플리케이션 개발 속도를 높이기 위한 일련의 도구와 도우미 기능을 제공하는 인기 있는 PHP 개발 프레임워크입니다. 그 중 Eloquent ORM은 Laravel 프레임워크에서 데이터베이스 작업에 사용되는 도구 중 하나로, Laravel 개발자가 데이터베이스를 보다 빠르게 쿼리하고 운영할 수 있도록 해줍니다. 이 기사에서는 데이터베이스 쿼리에 Eloquent ORM을 사용하는 방법을 살펴보겠습니다.

  1. Eloquent ORM 설치

먼저 Laravel 애플리케이션에 Eloquent ORM을 설치해야 합니다. Composer를 통해 Eloquent ORM을 설치하고 터미널을 열고 Laravel 프로젝트가 있는 폴더에 들어가서 다음 명령을 입력하면 됩니다.

1

composer require illuminate/database

로그인 후 복사

설치가 완료되면 config/database.php에서 데이터베이스 연결을 설정해야 합니다. , 아래와 같이:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

'connections' => [

 

    'mysql' => [

        'driver' => 'mysql',

        'host' => env('DB_HOST', '127.0.0.1'),

        'port' => env('DB_PORT', '3306'),

        'database' => env('DB_DATABASE', 'forge'),

        'username' => env('DB_USERNAME', 'forge'),

        'password' => env('DB_PASSWORD', ''),

        'unix_socket' => env('DB_SOCKET', ''),

        'charset' => 'utf8mb4',

        'collation' => 'utf8mb4_unicode_ci',

        'prefix' => '',

        'strict' => true,

        'engine' => null,

    ],

 

],

로그인 후 복사

또한 아래와 같이 .env 파일에서 데이터베이스 연결 관련 정보를 설정해야 합니다.

1

2

3

4

5

6

DB_CONNECTION=mysql

DB_HOST=127.0.0.1

DB_PORT=3306

DB_DATABASE=laravel

DB_USERNAME=root

DB_PASSWORD=

로그인 후 복사
  1. 모델 정의

Eloquent ORM을 사용하여 데이터베이스 쿼리를 수행하려면 다음이 필요합니다. 먼저 모델을 정의합니다. 모델은 데이터베이스 테이블을 나타내는 PHP 클래스를 나타냅니다. Laravel에서는 다음과 같이 artisan 명령을 통해 모델을 생성할 수 있습니다:

1

php artisan make:model User

로그인 후 복사

이렇게 하면 기본적으로 데이터베이스의 사용자 테이블에 매핑되는 User라는 모델이 생성됩니다. 다른 테이블에 매핑하려면 $table 속성을 사용하여 모델에 테이블 이름을 지정합니다.

1

2

3

4

class User extends Model

{

    protected $table = 'my_users';

}

로그인 후 복사
  1. Querying data

모델이 정의되면 Eloquent ORM을 사용하여 데이터베이스를 쿼리할 수 있습니다. 다음은 일반적으로 사용되는 몇 가지 쿼리 작업입니다.

(1) 모든 레코드 쿼리

1

$users = User::all();

로그인 후 복사

(2) ID를 기반으로 단일 레코드 쿼리

1

$user = User::find(1);

로그인 후 복사

(3) 다른 조건을 기반으로 결과 집합 쿼리

1

$users = User::where('name', 'John')->get();

로그인 후 복사

추가할 수 있습니다. where 메소드에서 같음, 같지 않음, 초과, 미만, in 등과 같은 일련의 제약 조건입니다.

1

2

3

$users = User::where('name', '=', 'John')->get();

$users = User::where('age', '>', 18)->get();

$users = User::whereIn('id', [1, 2, 3])->get();

로그인 후 복사

(4) 정렬

1

$users = User::orderBy('name', 'desc')->get();

로그인 후 복사

(5) 지정된 열 쿼리

1

$users = User::select('name', 'email')->get();

로그인 후 복사

select 메소드에서 여러 매개변수를 전달할 수 있으며, 각 매개변수는 쿼리할 열의 이름을 나타냅니다.

(6) 결과 집합 제한

1

$users = User::skip(10)->take(5)->get();

로그인 후 복사

skip 메서드를 사용하여 페이징을 구현할 수 있습니다. Skip 메서드는 지정된 수의 레코드를 건너뛰는 데 사용되고 take 메서드는 지정된 수의 레코드를 반환하는 데 사용됩니다. .

(7) 집계 함수 사용

1

2

3

4

$avg_age = User::avg('age');

$max_age = User::max('age');

$min_age = User::min('age');

$count = User::count();

로그인 후 복사

avg, max, min, count 등과 같은 일부 집계 함수를 사용할 수 있습니다.

  1. Update data

Eloquent ORM을 사용하여 레코드를 업데이트하면 먼저 레코드를 쿼리한 다음 모델 인스턴스에서 save 메소드를 호출할 수 있습니다.

1

2

3

$user = User::find(1);

$user->name = 'John';

$user->save();

로그인 후 복사

업데이트 메소드를 사용하여 여러 레코드를 업데이트할 수도 있습니다:

1

User::where('active', 1)->update(['status' => 'inactive']);

로그인 후 복사
  1. 데이터 삭제

Eloquent ORM을 사용하여 레코드를 삭제하면 먼저 레코드를 쿼리한 다음 모델 인스턴스에서 삭제 메소드를 호출할 수 있습니다.

1

2

$user = User::find(1);

$user->delete();

로그인 후 복사

destroy 메소드를 사용하여 여러 레코드를 삭제할 수도 있습니다.

1

User::destroy([1, 2, 3]);

로그인 후 복사

이렇게 하면 ID 1, 2, 3의 레코드가 삭제됩니다.

  1. Summary

이 글에서는 데이터베이스 쿼리에 Eloquent ORM을 사용하는 방법을 자세히 설명했습니다. Eloquent ORM은 Laravel 프레임워크의 매우 강력하고 유연한 도구로, 효율적이고 유지 관리가 가능한 데이터베이스 쿼리를 신속하게 구축하는 데 도움이 됩니다. Eloquent ORM에 대해 질문이나 의견이 있으시면 댓글로 남겨주세요.

위 내용은 Laravel 개발: 데이터베이스 쿼리에 Eloquent ORM을 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Laravel에서 이메일 전송이 실패 할 때 반환 코드를 얻는 방법은 무엇입니까? Laravel에서 이메일 전송이 실패 할 때 반환 코드를 얻는 방법은 무엇입니까? Apr 01, 2025 pm 02:45 PM

Laravel 이메일 전송이 실패 할 때 반환 코드를 얻는 방법. Laravel을 사용하여 응용 프로그램을 개발할 때 종종 확인 코드를 보내야하는 상황이 발생합니다. 그리고 실제로 ...

DCAT 관리자에서 데이터를 추가하기 위해 클릭하는 사용자 정의 테이블 기능을 구현하는 방법은 무엇입니까? DCAT 관리자에서 데이터를 추가하기 위해 클릭하는 사용자 정의 테이블 기능을 구현하는 방법은 무엇입니까? Apr 01, 2025 am 07:09 AM

DCAT를 사용할 때 DCATADMIN (LARAVEL-ADMIN)에서 데이터를 추가하려면 사용자 정의의 테이블 기능을 구현하는 방법 ...

Laravel Redis Connection 공유 : 선택 메소드가 다른 연결에 영향을 미치는 이유는 무엇입니까? Laravel Redis Connection 공유 : 선택 메소드가 다른 연결에 영향을 미치는 이유는 무엇입니까? Apr 01, 2025 am 07:45 AM

Laravel 프레임 워크 및 Laravel 프레임 워크 및 Redis를 사용할 때 Redis 연결을 공유하는 데 영향을 줄 수 있습니다. 개발자는 문제가 발생할 수 있습니다. 구성을 통해 ...

Laravel 멀티 테넌트 확장 STANCL/TENANCY : 테넌트 데이터베이스 연결의 호스트 주소를 사용자 정의하는 방법은 무엇입니까? Laravel 멀티 테넌트 확장 STANCL/TENANCY : 테넌트 데이터베이스 연결의 호스트 주소를 사용자 정의하는 방법은 무엇입니까? Apr 01, 2025 am 09:09 AM

Laravel 다중 테넌트 확장 패키지 패키지 패키지 패키지 패키지 Stancl/Tenancy, ...

Bangla 부분 모델 검색의 Laravel Eloquent Orm) Bangla 부분 모델 검색의 Laravel Eloquent Orm) Apr 08, 2025 pm 02:06 PM

Laraveleloquent 모델 검색 : 데이터베이스 데이터를 쉽게 얻을 수 있습니다. 이 기사는 데이터베이스에서 데이터를 효율적으로 얻는 데 도움이되는 다양한 웅변 모델 검색 기술을 자세히 소개합니다. 1. 모든 기록을 얻으십시오. 모든 () 메소드를 사용하여 데이터베이스 테이블에서 모든 레코드를 가져옵니다. 이것은 컬렉션을 반환합니다. Foreach 루프 또는 기타 수집 방법을 사용하여 데이터에 액세스 할 수 있습니다 : Foreach ($ postas $ post) {echo $ post->

Laravel6 프로젝트에서 Redis 연결의 유효성을 효과적으로 확인하는 방법은 무엇입니까? Laravel6 프로젝트에서 Redis 연결의 유효성을 효과적으로 확인하는 방법은 무엇입니까? Apr 01, 2025 pm 02:00 PM

Laravel6 프로젝트에서 Redis 연결의 유효성을 확인하는 방법은 특히 프로젝트가 비즈니스 처리를 위해 Redis에 의존 할 때 일반적인 문제입니다. 다음은 ...

Laravel 데이터베이스 마이그레이션은 중복 클래스 정의에 직면합니다 : 중복 마이그레이션 파일 및 클래스 이름 충돌을 해결하는 방법은 무엇입니까? Laravel 데이터베이스 마이그레이션은 중복 클래스 정의에 직면합니다 : 중복 마이그레이션 파일 및 클래스 이름 충돌을 해결하는 방법은 무엇입니까? Apr 01, 2025 pm 12:21 PM

Laravel 데이터베이스 마이그레이션 중 중복 클래스 정의 문제가 발생합니다. 데이터베이스 마이그레이션에 Laravel 프레임 워크를 사용하는 경우 개발자가 "클래스가 사용되었습니다 ...

LARAVEL 소개 예 LARAVEL 소개 예 Apr 18, 2025 pm 12:45 PM

Laravel은 웹 응용 프로그램을 쉽게 구축하기위한 PHP 프레임 워크입니다. 설치 : Composer를 사용하여 전 세계적으로 Laravel CLI를 설치하고 프로젝트 디렉토리에서 응용 프로그램을 작성하는 등 다양한 기능을 제공합니다. 라우팅 : Routes/Web.php에서 URL과 핸들러 간의 관계를 정의하십시오. 보기 : 리소스/뷰에서보기를 작성하여 응용 프로그램의 인터페이스를 렌더링합니다. 데이터베이스 통합 : MySQL과 같은 데이터베이스와 상자 외 통합을 제공하고 마이그레이션을 사용하여 테이블을 작성하고 수정합니다. 모델 및 컨트롤러 : 모델은 데이터베이스 엔티티를 나타내고 컨트롤러는 HTTP 요청을 처리합니다.

See all articles