찾다
PHP 프레임워크LaravelLaravel Eloquent에 대한 필수 실무 팁

Laravel Eloquent

1. 증가 및 감소

는 다음 구현으로 대체되어야 합니다.

$article = Article::find($article_id);
$article->read_count++;
$article->save();

이를 수행할 수 있습니다.

$article = Article::find($article_id);
$article->increment('read_count');

다음 방법도 구현할 수 있습니다.

Article::find($article_id)->increment('read_count');
Article::find($article_id)->increment('read_count', 10); // +10
Product::find($produce_id)->decrement('stock'); // -1

2. X 메소드 먼저, If 메소드

예제 1 -- findOrFail():

다음 코드의 구현을 바꾸려면:

$user = User::find($id);
if (!$user) { abort (404); }

다음과 같이 작성할 수 있습니다.

$user = User::findOrFail($id);

예제 2 -- firstOrCreate():

다음 코드의 구현을 바꾸려면 코드:

$user = User::where('email', $email)->first();
if (!$user) {
  User::create([
    'email' => $email
  ]);
}

다음과 같이 작성하세요:

$user = User::firstOrCreate(['email' => $email]);

3. 모델의 boot() 메소드

Eloquent 모델에는 boot()라는 마법의 장소가 있는데, 여기서 기본 동작을 무시할 수 있습니다:

class User extends Model
{
    public static function boot()
    {
        parent::boot();
        static::updating(function($model)
        {
            // 写点日志啥的
            // 覆盖一些属性,类似这样 $model->something = transform($something);
        });
    }
}

모델 객체를 생성할 때 특정 필드의 값을 설정하는 것은 아마도 가장 인기 있는 예 중 하나일 것입니다. 모델 객체 생성 시 UUID 필드를 생성하고 싶다면 어떻게 해야 하는지 살펴보겠습니다.

public static function boot()
{
  parent::boot();
  self::creating(function ($model) {
    $model->uuid = (string)Uuid::generate();
  });
}

4. 조건과 정렬을 사용한 연관

연관을 정의하는 일반적인 방법:

public function users()
{
    return $this->hasMany('App\User');
}

알고 계시나요? 위 내용을 기반으로 where 또는 orderBy를 추가할 수도 있습니다.

예를 들어 특정 유형의 사용자를 연결하고 이메일 필드를 사용하여 정렬하려면 다음을 수행할 수 있습니다.

public function approvedUsers() {
    return $this->hasMany('App\User')->where('approved', 1)->orderBy('email');
}

5 모델 기능: 시간, 추가. 잠깐

Eloquent 모델에는 클래스의 속성 형식을 사용하는 몇 가지 매개변수가 있습니다. 가장 일반적으로 사용되는 기능은 다음과 같습니다.

class User extends Model
{
    protected $table = 'users';
    protected $fillable = ['email', 'password']; // 可以被批量赋值字段,如 User::create() 新增时,可使用字段
    protected $dates = ['created_at', 'deleted_at']; // 需要被Carbon维护的字段名
    protected $appends = ['field1', 'field2']; // json返回时,附加的字段
}

이것들뿐만 아니라:

protected $primaryKey = 'uuid'; // 更换主键
public $incrementing = false; // 设置 不自增长
protected $perPage = 25; // 定义分页每页显示数量(默认15)
const CREATED_AT = 'created_at';
const UPDATED_AT = 'updated_at'; //重写 时间字段名
public $timestamps = false; // 设置不需要维护时间字段

몇 가지 흥미로운 기능만 나열했습니다. 모든 기능에 대한 자세한 내용은 문서 추상 모델 클래스를 참조하세요.

6 .ID노트로 여러 항목 조회

find() 메소드는 다들 아시죠?

$user = User::find(1);

이 방법이 여러 ID의 배열을 매개변수로 허용할 수 있다는 사실을 아는 사람이 거의 없다는 사실에 매우 놀랐습니다.

$users = User::find([1,2,3]);

7. WhereX

이 코드를

$users = User::where('approved', 1)->get();

로 변환하는 우아한 방법이 있습니다. 예, 올바르게 읽으셨습니다. 필드 이름을 접미사로 사용하고 where에 추가하면 마법의 방법을 통해 실행됩니다.

또한 Eloquent에는 시간과 관련하여 미리 정의된 몇 가지 방법이 있습니다:

$users = User::whereApproved(1)->get();

8. 관계별 정렬

좀 더 복잡한 "기술"입니다. 최신 게시물을 기준으로 포럼 주제를 정렬하시겠습니까? 가장 최근에 업데이트된 주제를 포럼 상단에 표시하는 것은 일반적인 요구 사항입니다. 그렇죠?

먼저, 주제의 최신 게시물에 대해 별도의 관계를 정의합니다:

User::whereDate('created_at', date('Y-m-d'));
User::whereDay('created_at', date('d'));
User::whereMonth('created_at', date('m'));
User::whereYear('created_at', date('Y'));

그런 다음 컨트롤러에서 이 "마법"을 구현할 수 있습니다:

public function latestPost()
{
    return $this->hasOne(\App\Post::class)->latest();
}

9. Eloquent::when() -- 더 이상 if -else

많은 사람들이 쿼리 조건을 작성하기 위해 "if-else"를 사용하는 것을 좋아합니다. 전달 매개변수:

$users = Topic::with('latestPost')->get()->sortByDesc('latestPost.created_at');

10.BelongsTo 기본 모델

Author 모델에 Post 모델이 첨부된 경우 Blade 템플릿에 다음 코드를 작성할 수 있습니다.

if (request('filter_by') == 'likes') {
    $query->where('likes', '>', request('likes_amount', 0));
}
if (request('filter_by') == 'date') {
    $query->orderBy('created_at', request('ordering_rule', 'desc'));
}

그러나 작성자가 삭제되거나 일부 문제로 인해 이유가 설정되지 않았나요? "존재하지 않는 개체 속성"과 같은 오류 메시지가 표시됩니다.

따라서 다음과 같이 피할 수 있습니다:

$query = Author::query();
$query->when(request('filter_by') == 'likes', function ($q) {
    return $q->where('likes', '>', request('likes_amount', 0));
});
$query->when(request('filter_by') == 'date', function ($q) {
    return $q->orderBy('created_at', request('ordering_rule', 'desc'));
});

하지만 Eloquent 관계 모델 수준에서는 이 작업을 수행할 수 있습니다.

$query = User::query();
$query->when(request('role', false), function ($q, $role) {
    return $q->where('role_id', $role);
});
$authors = $query->get();

이 예에서 게시물에 작성자가 없으면 작성자() 관계 메서드는 빈 값을 반환합니다. AppAuthor 모델 객체.

또한 기본 모델에 기본 속성 값을 할당할 수도 있습니다.

{{ $post->author->name }}

11. 할당 기능으로 정렬

다음 코드가 있다고 가정해 보세요.

{{ $post->author->name ?? '' }}

이제 "full_name"으로 정렬하려고 합니까? 효과가 없다는 것을 알았습니다.

public function author()
{
    return $this->belongsTo('App\Author')->withDefault();
}

해결 방법은 간단합니다. 결과를 얻은 후 정렬됩니다.

public function author()
{
    return $this->belongsTo('App\Author')->withDefault([
        'name' => 'Guest Author'
    ]);
}

메서드 이름이 다르다는 점에 유의하세요. orderBy가 아니라 sortBy입니다

12. 전역 범위의 기본 정렬

사용자가 원하는 경우:all()은 항상 정렬합니다. 이름 필드로? 전역 범위를 할당할 수 있습니다. 위에서 언급한 boot() 메서드로 돌아가 보겠습니다.

function getFullNameAttribute()
{
  return $this->attributes['first_name'] . ' ' . $this->attributes['last_name'];
}

확장 읽기 쿼리 범위.

13. 네이티브 쿼리 방법

때로는 Eloquent 문에 네이티브 쿼리를 추가해야 할 때가 있습니다. 다행히도 방법이 있습니다.

$clients = Client::orderBy('full_name')->get(); //没有效果

14. 복사: 한 줄을 복사하는

은 쉽습니다. 설명은 그다지 심층적이지 않지만 데이터베이스 엔터티(데이터 조각)를 복사하는 가장 좋은 방법은 다음과 같습니다.

$clients = Client::get()->sortBy('full_name'); // 成功!

15. 큰 데이터 덩어리의 Chunk() 메서드

는 Eloquent와 완전히 관련이 없습니다. , 이는 컬렉션에 관한 것이지만 여전히 대규모 데이터 컬렉션을 처리하는 데 매우 유용합니다. Chunk()를 사용하여 이 데이터를 작은 데이터 청크로 분할할 수 있습니다

수정 전:

protected static function boot()
{
    parent::boot();
    // 按照 name 正序排序
    static::addGlobalScope('order', function (Builder $builder) {
        $builder->orderBy('name', 'asc');
    });
}

이렇게 할 수 있습니다:

// whereRaw
$orders = DB::table('orders')
    ->whereRaw('price > IF(state = "TX", ?, 100)', [200])
    ->get();
// havingRaw
Product::groupBy('category_id')->havingRaw('COUNT(*) > 1')->get();
// orderByRaw
User::where('created_at', '>', '2016-01-01')
  ->orderByRaw('(updated_at - created_at) desc')
  ->get();

16 모델을 생성할 때 추가 작업을 추가하세요

우리 모두는 Artisan 명령을 알고 있습니다:

$task = Tasks::find(1);
$newTask = $task->replicate();
$newTask->save();

하지만 모델 관련 파일을 생성하는 데 사용할 수 있는 매우 유용한 세 가지 식별자가 있다는 것을 알고 있습니다.

$users = User::all();
foreach ($users as $user) {
    // ...

-m 마이그레이션 파일 생성

-c 컨트롤러 파일 생성

-r 컨트롤러에 리소스 작업 방법 추가

17. update_at 저장 방법

你知道 ->save() 方法可以接受参数吗? 我们可以通过传入参数阻止它的默认行为:更新 updated_at 的值为当前时间戳。

$product = Product::find($id);
$product->updated_at = '2019-01-01 10:00:00';
$product->save(['timestamps' => false]);

这样,我们成功在 save 时指定了 updated_at 的值。

18. update() 的结果是什么?

你是否想知道这段代码实际上返回什么?

$result = $products->whereNull('category_id')->update(['category_id' => 2]);

我是说,更新操作是在数据库中执行的,但 $result 会包含什么?

答案是受影响的行。 因此如果你想检查多少行受影响, 你不需要额外调用其他任何内容 -- update() 方法会给你返回此数字。

19. 把括号转换成 Eloquent 查询

如果你有个 and 和 or 混合的 SQL 查询,像这样子的:

... WHERE (gender = 'Male' and age >= 18) or (gender = 'Female' and age >= 65)

怎么用 Eloquent 来翻译它呢? 下面是一种错误的方式:

$q->where('gender', 'Male');
$q->orWhere('age', '>=', 18);
$q->where('gender', 'Female');
$q->orWhere('age', '>=', 65);

顺序就没对。正确的打开方式稍微复杂点,使用闭包作为子查询:

$q->where(function ($query) {
    $query->where('gender', 'Male')
        ->where('age', '>=', 18);
})->orWhere(function($query) {
    $query->where('gender', 'Female')
        ->where('age', '>=', 65);
})

20. 复数参数的 orWhere

终于,你可以传递阵列参数给 orWhere()。平常的方式:

$q->where('a', 1);
$q->orWhere('b', 2);
$q->orWhere('c', 3);

你可以这样做:

$q->where('a', 1);
$q->orWhere(['b' => 2, 'c' => 3]);

更多laravel框架相关技术文章,请访问laravel教程栏目!

위 내용은 Laravel Eloquent에 대한 필수 실무 팁의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 ruoxiaozh에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Laravel (PHP) vs. Python : 장단점의 무게Laravel (PHP) vs. Python : 장단점의 무게Apr 17, 2025 am 12:18 AM

Laravel은 웹 응용 프로그램을 빠르게 구축하는 데 적합하지만 Python은 광범위한 응용 프로그램 시나리오에 적합합니다. 1. Laravel은 웹 개발을 단순화하기 위해 Eloquentorm, Blade Template Engine 및 Artisan 도구를 제공합니다. 2. Python은 동적 유형, 풍부한 표준 라이브러리 및 타사 생태계로 유명하며 웹 개발, 데이터 과학 및 기타 분야에 적합합니다.

Laravel vs. Python : 프레임 워크 및 라이브러리 비교Laravel vs. Python : 프레임 워크 및 라이브러리 비교Apr 17, 2025 am 12:16 AM

Laravel과 Python은 각각 고유 한 장점을 가지고 있습니다. Laravel은 기능이 풍부한 웹 애플리케이션을 빠르게 구축하는 데 적합하며 Python은 데이터 과학 및 일반 프로그래밍 분야에서 잘 작동합니다. 1. Laravel은 현대적인 웹 애플리케이션을 구축하는 데 적합한 Eloquentorm 및 Blade Template 엔진을 제공합니다. 2. Python에는 풍부한 표준 라이브러리와 타사 라이브러리가 있으며 Django 및 Flask 프레임 워크는 다양한 개발 요구를 충족시킵니다.

Laravel의 목적 : 강력하고 우아한 웹 응용 프로그램 구축Laravel의 목적 : 강력하고 우아한 웹 응용 프로그램 구축Apr 17, 2025 am 12:13 AM

Laravel은 코드 구조를 명확하게하고 개발 프로세스를보다 예술적으로 만들 수 있기 때문에 선택할 가치가 있습니다. 1) Laravel은 PHP를 기반으로하며 MVC 아키텍처를 따르며 웹 개발을 단순화합니다. 2) eloquentorm, 장인 도구 및 블레이드 템플릿과 같은 핵심 기능은 개발의 우아함과 견고성을 향상시킵니다. 3) 라우팅, 컨트롤러, 모델 및 뷰를 통해 개발자는 응용 프로그램을 효율적으로 구축 할 수 있습니다. 4) 큐 및 이벤트 모니터링과 같은 고급 기능은 응용 프로그램 성능을 더욱 향상시킵니다.

Laravel : 주로 백엔드 프레임 워크가 설명되었습니다Laravel : 주로 백엔드 프레임 워크가 설명되었습니다Apr 17, 2025 am 12:02 AM

Laravel은 백엔드 프레임 워크 일뿐 만 아니라 완전한 웹 개발 솔루션이기도합니다. 라우팅, 데이터베이스 운영, 사용자 인증 등과 같은 강력한 백엔드 기능을 제공하고 프론트 엔드 개발을 지원하여 전체 웹 응용 프로그램의 개발 효율성을 향상시킵니다.

Laravel (PHP) vs. Python : 주요 차이점 이해Laravel (PHP) vs. Python : 주요 차이점 이해Apr 17, 2025 am 12:01 AM

Laravel은 웹 개발에 적합하며 Python은 데이터 과학 및 빠른 프로토 타이핑에 적합합니다. 1. Laravel은 PHP를 기반으로하며 Eloquentorm과 같은 우아한 구문 및 풍부한 기능을 제공합니다. 2. Python은 단순성으로 유명하며 웹 개발 및 데이터 과학에 널리 사용되며 풍부한 라이브러리 생태계가 있습니다.

Laravel In Action : 실제 응용 프로그램 및 예제Laravel In Action : 실제 응용 프로그램 및 예제Apr 16, 2025 am 12:02 AM

laravelcanbeefectically-Worldapplicationsforlybuildingscaleberquentorm.2) laravel'secosystem, Enhancesdevelopment.3) eTaddressespesperformance를 포함하여

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

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

Laravel의 백엔드 기능 : 데이터베이스, 논리 등Laravel의 백엔드 기능 : 데이터베이스, 논리 등Apr 14, 2025 am 12:04 AM

Laravel은 백엔드 개발에서 강력하게 수행되며 Eloquentorm, 컨트롤러 및 서비스 클래스를 통해 데이터베이스 작업을 단순화하고 대기열, 이벤트 및 기타 기능을 제공합니다. 1) Eloquentorm은 쿼리를 단순화하기 위해 모델을 통해 데이터베이스 테이블을 맵핑합니다. 2) 비즈니스 로직은 모듈성 및 유지 관리를 향상시키기 위해 컨트롤러 및 서비스 클래스에서 처리됩니다. 3) 큐 시스템과 같은 다른 기능은 복잡한 요구를 처리하는 데 도움이됩니다.

See all articles

핫 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尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기