Docs Menu
Docs Home
/ / /
Laravel MongoDB
/

Eloquent 모델 클래스

이 페이지의 내용

  • 개요
  • Eloquent 모델 클래스 정의
  • 인증 가능 모델 확장
  • Eloquent 모델 클래스 사용자 지정
  • 모델 컬렉션 이름 변경
  • 기본 키 필드 변경
  • 일시 삭제 활성화
  • 캐스트 데이터 유형
  • 대량 할당 사용자 지정
  • 타사 모델 클래스 확장
  • 확장 클래스 예제
  • 정리 동작 지정
  • 정리 가능한 예제
  • 대량 정리 가능 예제
  • 버전이 지정된 모델 스키마 만들기
  • 스키마 버전 관리 예시

이 가이드 에서는 Laravel MongoDB 를 사용하여 Laravel Eloquent 모델을 정의하고 사용자 지정하는 방법을 보여줍니다. 이러한 모델을 사용하면 Laravel Eloquent 객체 관계형 매퍼(ORM)를 사용하여 MongoDB 데이터로 작업할 수 있습니다.

다음 섹션에서는 Laravel MongoDB 모델에 Laravel Eloquent ORM 동작을 추가하는 방법을 설명합니다.

  • Eloquent 모델 클래스 정의에서는 모델 클래스 를 생성하는 방법을 설명합니다.

  • 인증 가능 모델 확장에서는 MongoDB를 인증 사용자 제공자로 설정하는 방법을 보여줍니다.

  • Eloquent 모델 클래스 사용자 정의에서는 몇 가지 모델 클래스 사용자 정의에 대해 설명합니다.

  • 타사 모델 클래스 확장 에서는 타사 모델 클래스를 MongoDB 와 호환되도록 만드는 방법을 설명합니다.

  • 가지 치기 동작 지정 에서는 더 이상 필요하지 않은 모델을 주기적으로 제거하는 방법을 보여 줍니다.

  • 버전이 지정된 모델 스키마 생성 에서는 모델 스키마 버전 관리를 구현 하는 방법을 보여 줍니다.

Eloquent 모델은 데이터를 나타내는 클래스입니다. 여기에는 삽입, 업데이트, 삭제와 같은 데이터베이스 작업을 수행하는 메서드가 포함됩니다.

Laravel MongoDB 모델을 선언하려면 다음 코드 예시와 같이 Laravel 애플리케이션의 app/Models 디렉토리에 MongoDB\Laravel\Eloquent\Model 를 확장하는 클래스를 만듭니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\Model;
class Planet extends Model
{
}

기본값 모델은 Laravel 애플리케이션의 config/database.php 설정에 설정하다 MongoDB database 이름과 컬렉션 에 대한 모델 클래스 이름의 스네이크 복수형을 사용합니다.

이 모델은 planets MongoDB 컬렉션에 저장됩니다.

또는 artisan 콘솔을 사용하여 모델 클래스를 생성하고 Illuminate\Database\Eloquent\Model 가져오기를 MongoDB\Laravel\Eloquent\Model 로 변경합니다. 콘솔에 학습 보려면 Laravel Docs 에서 artisan 아티즌 콘솔 Docs을 참조하세요.

Laravel 애플리케이션 에서 사용하는 데이터베이스 이름을 지정하는 방법을 학습 보려면 MongoDB 연결 구성을 참조하세요.

MongoDB 를 Laravel 사용자 제공자 로 구성하려면 Laravel 통합 MongoDB\Laravel\Auth\User 클래스를 확장하면 됩니다. 다음 코드 예시 에서는 이 클래스를 확장하는 방법을 보여 줍니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Auth\User as Authenticatable;
class User extends Authenticatable
{
}

Laravel 인증 사용자 제공자를 사용자 지정하는 방법에 대해 자세히 알아보려면 사용자 지정 사용자 제공자 추가 하기를 Docs 참조하세요. Laravel 에서 .

이 섹션에서는 다음과 같은 Eloquent 모델 동작 사용자 지정을 수행하는 방법을 보여줍니다.

기본적으로 이 모델은 모델 클래스 이름에 스네이크형 복수형을 사용합니다. 모델이 MongoDB에서 데이터를 검색하고 저장하는 데 사용하는 컬렉션의 이름을 변경하려면 모델 클래스의 $table 속성을 재정의합니다.

참고

모델과 컬렉션 간의 연결을 간단하게 유지하려면 기본 컬렉션 명명 동작을 사용하는 것이 좋습니다.

다음 예제에서는 Planet 클래스에 대한 사용자 지정 MongoDB 컬렉션 이름 celestial_body 을 지정합니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\Model;
class Planet extends Model
{
protected $table = 'celestial_body';
}

$table 속성 을 재정의하지 않고 이 모델은 planets 컬렉션 에 매핑합니다. 재정의된 속성 을 사용하면 예시 클래스는 celestial_body 컬렉션 에 모델을 저장합니다.

MongoDB 문서를 고유하게 식별하는 모델의 기본 키 필드를 사용자 지정하려면 모델 클래스의 $primaryKey 속성을 재정의합니다.

기본값 으로 이 모델은 PHP MongoDB 운전자 를 사용하여 Laravel 애플리케이션 이 삽입하는 각 문서 에 대해 고유한 ObjectID를 생성합니다.

다음 예시에서는 name 필드를 Planet 클래스의 프라이머리 키로 지정합니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\Model;
class Planet extends Model
{
protected $primaryKey = 'name';
}

프라이머리 키 동작 및 사용자 지정 옵션에 대해 자세히 알아보려면 Eloquent 프라이머리 키 Docs 를 참조하세요. Laravel 에서 .

_id 필드, ObjectID 및 MongoDB 문서 구조에 학습 보려면 서버 매뉴얼의 문서 를 참조하세요.

Eloquent에는 모델에서 delete() 메서드의 동작을 변경하는 일시 삭제 기능이 포함되어 있습니다. 모델에서 일시 삭제가 활성화된 경우 delete() 메서드는 데이터베이스에서 문서를 제거하는 대신 문서를 삭제된 것으로 표시합니다. deleted_at 필드에 타임스탬프를 설정하여 검색 작업에서 자동으로 제외합니다.

클래스에서 일시 삭제를 활성화 하려면 다음 코드 예시 와 같이 MongoDB\Laravel\Eloquent\SoftDeletes 트레이트를 추가합니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\Model;
use MongoDB\Laravel\Eloquent\SoftDeletes;
class Planet extends Model
{
use SoftDeletes;
}

일시 삭제가 활성화된 모델에서 수행할 수 있는 메서드에 대해 알아보려면 Eloquent 소프트 삭제 Docs를 참조하세요. Laravel 에서 .

Eloquent를 사용하면 캐스팅 헬퍼를 사용하여 데이터를 저장하거나 검색하기 전에 모델 속성 데이터 유형을 변환할 수 있습니다. 이 헬퍼는 모델에서 동등한 접근자 및 변경자 메서드를 정의하는 대신 편리한 대안입니다.

다음 예시 에서 캐스팅 헬퍼는 discovery_dt MongoDB 에 MongoDB\\ BSON\\UTCDateTime 유형으로 저장된 모델 속성을 Laravel datetime 유형으로 변환합니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\Model;
class Planet extends Model
{
protected $casts = [
'discovery_dt' => 'datetime',
];
}

Laravel 11의 캐스트

Laravel 11 에서는 $casts 속성을 사용하는 대신 casts() 메서드를 정의하여 데이터 유형 변환을 지정할 수 있습니다. 다음 코드는 casts() 메서드를 사용하여 이전 예제와 동일한 변환을 수행합니다.

protected function casts(): array
{
return [
'discovery_dt' => 'datetime',
];
}

학습 보려면 속성 캐스팅 을 참조하세요. Laravel 문서에서 확인할 수 있습니다.

이 변환을 사용하면 PHP DateTime 클래스를 사용하여 이 필드 의 날짜를 처리할 수 있습니다. 다음 예시 는 모델의 캐스팅 헬퍼를 사용하여 discovery_dt 가 3년 미만인 행성을 쿼리 하는 Laravel 쿼리 를 보여줍니다.

Planet::where( 'discovery_dt', '>', new DateTime('-3 years'))->get();

참고

탄소 날짜 클래스

Laravel MongoDB v5.0 부터 시작됩니다. UTCDateTime MongoDB 의 BSON 값은 다음으로 반환됩니다. 쿼리 결과의 날짜 클래스. Laravel 통합은 이 변환을 수행할 때 기본값 시간대를 적용합니다.

MongoDB 의 데이터 유형에 학습 보려면 서버 매뉴얼에서 BSON types 를 참조하세요.

Laravel 캐스팅 헬퍼 및 지원되는 유형에 대해 자세히 알아보려면 속성 캐스팅 을 Docs참조하세요. Laravel 에서 .

Eloquent를 사용하면 데이터 배열 을 create() 모델 메서드에 전달하여 여러 모델과 해당 모델의 속성 데이터를 생성할 수 있습니다. 여러 모델을 삽입하는 이 프로세스 를 대량 할당이라고 합니다.

대량 할당은 여러 모델을 생성하는 효율적인 방법이 될 수 있습니다. 그러나 악용 가능한 보안 취약점이 노출될 수 있습니다. 필드의 데이터에는 무단 권한 또는 액세스로 이어지는 업데이트가 포함되어 있을 수 있습니다.

Eloquent는 대량 할당 취약점으로부터 데이터를 보호하기 위해 다음과 같은 특성을 제공합니다.

  • $fillable 대량 할당에서 쓰기 가능한 필드를 포함합니다.

  • $guarded 대량 할당에서 무시되는 필드를 포함합니다.

중요

취약점으로부터 보호하려면 대신 를 사용하는 것이 $fillable 좋습니다.$guarded 이 권장 사항에 대해 자세히 알아보려면 보안 릴리스: Laravel 6.18.35, 7.24 을 참조하세요.0 Laravel 사이트의 문서입니다.

다음 예제에서 모델은 $fillable 속성을 사용하여 필드를 대량 할당할 수 있습니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\Model;
class Planet extends Model
{
protected $fillable = [
'name',
'gravitational_force',
'diameter',
'moons',
];
}

다음 코드 예시에서는 Planet 모델의 대량 할당을 보여 줍니다.

$planets = [
[ 'name' => 'Earth', 'gravitational_force' => 9.8, 'day_length' => '24 hours' ],
[ 'name' => 'Mars', 'gravitational_force' => 3.7, 'day_length' => '25 hours' ],
];
Planet::create($planets);

데이터베이스에 저장된 모델에는 $fillable 속성에서 day_length 가 생략되었으므로 namegravity 필드만 포함됩니다.

배열에서 생략된 필드를 채우려고 할 때 동작을 변경하는 방법을 알아보려면 $fillable 대량 할당 예외 를 Docs참조하세요. Laravel 에서 .

Laravel 통합을 사용하여 모델 클래스를 정의할 때 DocumentModel 트레이트를 포함하여 타사 모델 클래스를 확장할 수 있습니다. By including this trait, you can make the third-party class compatible with MongoDB.

모델 클래스에 DocumentModel 특성을 적용 할 때는 Laravel 통합이 MongoDB ObjectId 값을 string 유형으로 캐스팅하므로 $keyType 속성 을 'string' 로 설정하다 해야 합니다.

이 예시 에서는 ThirdPartyPackage 패키지 에서 CelestialBody 클래스를 확장하는 Planet 모델 클래스를 만듭니다. Post 클래스는 DocumentModel 트레이트를 포함하며 $primaryKey$keyType 등의 속성을 정의합니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\DocumentModel;
use ThirdPartyPackage\CelestialBody;
class Planet extends CelestialBody
{
use DocumentModel;
protected $fillable = ['name', 'diameter'];
protected $keyType = 'string';
}

클래스를 정의한 후에는 평소대로 MongoDB 작업을 수행할 수 있습니다.

DocumentModel 트레이트를 사용하는 또 다른 예시 를 보려면 사용자 인증 가이드 의 Laravel 생텀 섹션을 참조하세요.

Eloquent를 사용하면 더 이상 필요하지 않은 모델 데이터를 주기적으로 삭제하는 기준을 지정할 수 있습니다. model:prune 명령을 예약하거나 실행할 때 Laravel은 삭제할 모델과 일치시키기 위해 PrunableMassPrunable 트레이트를 가져오는 모든 모델에서 prunable() 메서드를 호출합니다.

MongoDB를 데이터베이스로 사용하는 모델에서 이 기능을 사용하려면 모델에 적절한 가져오기를 추가합니다.

  • MongoDB\Laravel\Eloquent\Prunable 기준과 일치하는 모델을 삭제하기 전에 선택적으로 정리 단계를 수행합니다.

  • MongoDB\Laravel\Eloquent\MassPrunable 모델 데이터를 가져오지 않고 기준과 일치하는 모델을 삭제합니다.

참고

대량 정리 가능 모델에서 일시 삭제를 활성화하는 경우 다음 Laravel MongoDB 패키지를 가져와야 합니다.

  • MongoDB\Laravel\Eloquent\SoftDeletes

  • MongoDB\Laravel\Eloquent\MassPrunable

정리 기능 에 학습 보려면 모델 정리 를 Docs 참조하세요. Laravel 에서 .

다음 정리 가능한 클래스에는 정리 작업이 삭제한 모델과 일치하는 prunable() 메서드와 일치하는 모델을 삭제하기 전에 실행되는 pruning() 메서드가 포함됩니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\Model;
use MongoDB\Laravel\Eloquent\Prunable;
class Planet extends Model
{
use Prunable;
public function prunable()
{
// matches models in which the solar_system field contains a null value
return static::whereNull('solar_system');
}
protected function pruning()
{
// Add cleanup actions, such as logging the Planet 'name' attribute
}
}

다음 대량 정리 가능 클래스에는 정리 작업이 삭제하는 모델과 일치하는 prunable() 메서드가 포함되어 있습니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\MassPrunable;
use MongoDB\Laravel\Eloquent\Model;
class Planet extends Model
{
use MassPrunable;
public function prunable()
{
// matches models in which the gravitational_force field contains
// a value greater than 0.5
return static::where('gravitational_force', '>', 0.5);
}
}

Eloquent 모델에서 HasSchemaVersion 트레이트를 사용하여 애플리케이션 에 스키마 버전 패턴 을 구현 수 있습니다. 스키마 버전을 구현 하여 다양한 스키마의 데이터가 포함된 컬렉션 을 구성하거나 표준화할 수 있습니다.

스키마 버전 관리에 학습 보려면 서버 매뉴얼의 스키마 버전 관리를 위한 모델 데이터 튜토리얼을 참조하세요.

MongoDB 를 데이터베이스 로 사용하는 모델에서 이 기능 을 사용하려면 모델에 MongoDB\Laravel\Eloquent\HasSchemaVersion 가져오기를 추가합니다. 그런 다음 SCHEMA_VERSION 상수를 1 로 설정하다 하여 컬렉션 의 첫 번째 스키마 버전을 설정하다 합니다. 컬렉션 이 여러 스키마를 포함하도록 발전하는 경우 후속 모델 클래스에서 SCHEMA_VERSION 상수 값을 업데이트 할 수 있습니다.

모델을 만들 때 migrateSchema() 메서드를 정의하여 모델 검색 시 현재 스키마 버전으로 마이그레이션 하도록 지정할 수 있습니다. 이 방법에서는 이전 모델에 적용할 변경 사항을 지정하여 현재 스키마 버전과 일치하도록 업데이트 할 수 있습니다.

스키마 버전이 지정되지 않은 모델을 저장하는 경우 HasSchemaVersion 특성은 해당 모델이 최신 스키마 버전을 따른다고 가정합니다. schema_version 필드 를 포함하지 않는 모델을 조회 할 때 특성은 해당 스키마 버전이 0 라고 가정하고 마이그레이션 을 수행합니다.

이 샘플 상황에서는 다음 클래스에 의해 처음 모델링된 컬렉션 으로 작업하고 있습니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\Model;
class Planet extends Model
{
protected $fillable = ['name', 'type'];
}

이제 컬렉션 에 새 스키마 버전을 구현 하려고 합니다. 다음 동작을 사용하여 새 모델 클래스를 정의할 수 있습니다.

  • HasSchemaVersion 트레이트를 구현하고 현재 SCHEMA_VERSION 을(를) 2으)로 설정합니다.

  • 스키마 버전이 2 미만인 모델을 마이그레이션 하여 값이 'Milky Way'galaxy 필드 를 갖도록 migrateSchema() 메서드를 정의합니다.

<?php
namespace App\Models;
use MongoDB\Laravel\Eloquent\HasSchemaVersion;
use MongoDB\Laravel\Eloquent\Model;
class Planet extends Model
{
use HasSchemaVersion;
public const SCHEMA_VERSION = 2;
protected $fillable = ['name', 'type', 'galaxy'];
/**
* Migrate documents with a lower schema version to the most current
* schema when inserting new data or retrieving from the database.
*/
public function migrateSchema(int $fromVersion): void
{
if ($fromVersion < 2) {
$this->galaxy = 'Milky Way';
}
}
}

다음 코드의 "WASP-39 b" 문서 에서 schema_version 필드 값이 2 보다 작습니다. 문서 를 조회 하면 Laravel 통합이 galaxy 필드 를 추가하고 스키마 버전을 현재 버전인 2 로 업데이트합니다.

"Saturn" 문서 에 schema_version 필드 가 포함되어 있지 않으므로 저장 시 Laravel Integration이 현재 스키마 버전을 할당합니다.

마지막으로 이 코드는 컬렉션 에서 모델을 검색하여 변경 사항을 시연합니다.

// Simulates a document in the collection with schema version 1
Planet::insert([
[
'name' => 'WASP-39 b',
'type' => 'gas',
'schema_version' => 1,
],
]);
// Saves a document with no specified schema version
$saturn = Planet::create([
'name' => 'Saturn',
'type' => 'gas',
]);
// Retrieves both models from the collection
$planets = Planet::where('type', 'gas')
->get();
[
{
"_id": ...,
"name": "WASP-39 b",
"type": "gas",
"galaxy": "Milky Way",
"schema_version": 2,
},
{
"_id": ...,
"name": "Saturn",
"type": "gas",
"schema_version": 2,
}
]

돌아가기

Eloquent 모델