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

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

WBOY
WBOY원래의
2023-06-14 12:47:411465검색

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

  1. Eloquent ORM 설치

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

composer require illuminate/database

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

'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 파일에서 데이터베이스 연결 관련 정보를 설정해야 합니다.

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 명령을 통해 모델을 생성할 수 있습니다:

php artisan make:model User

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

class User extends Model
{
    protected $table = 'my_users';
}
  1. Querying data

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

(1) 모든 레코드 쿼리

$users = User::all();

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

$user = User::find(1);

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

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

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

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

(4) 정렬

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

(5) 지정된 열 쿼리

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

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

(6) 결과 집합 제한

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

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

(7) 집계 함수 사용

$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 메소드를 호출할 수 있습니다.

$user = User::find(1);
$user->name = 'John';
$user->save();

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

User::where('active', 1)->update(['status' => 'inactive']);
  1. 데이터 삭제

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

$user = User::find(1);
$user->delete();

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

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으로 문의하세요.