検索

Laravel のクエリ スコープは、アプリケーション全体で再利用するためにモデル内で一般的に使用されるクエリ メソッドを定義できるようにする非常に重要な機能です。これらのクエリ スコープは、グローバル (モデル全体に​​適用) またはローカル (モデルのメソッドのみに適用) にすることができます。

この記事では、Laravelにおけるクエリスコープの定義や使い方、注意点などを紹介します。

  1. クエリ スコープの定義

クエリ スコープは、Eloquent クエリ ビルダー インスタンスである $query パラメーターを受け取る匿名関数です。この匿名関数では、where 句や order by 句の追加など、インスタンスに対していくつかのクエリ操作を実行できます。

次は、基本的なクエリ スコープ定義の例です:

public function scopePublished($query)
{
    return $query->where('status', '=', 'published');
}

上の例では、published という名前のクエリ スコープを定義します。これにより、where 句をクエリするときに、Published をフィルタリングするクエリ スコープが自動的に追加されます。モデル。

  1. クエリ スコープの使用

クエリ スコープの使用は非常に簡単で、モデルの対応するメソッドを呼び出すだけです。たとえば、上記の例で公開されたクエリ スコープを使用する場合、次のコードを呼び出すだけで済みます。

$posts = Post::published()->get();

上記のコードは、公開されたすべての Post インスタンスのコレクションを返します。

パラメータをクエリ スコープに渡す必要がある場合は、このメソッドにパラメータを追加するだけです。例:

public function scopeCategory($query, $categoryId)
{
    return $query->where('category_id', '=', $categoryId);
}

このクエリ スコープを使用して、特定のカテゴリのブログ投稿をフィルタリングできます。

$posts = Post::category(1)->get();

上記のコードは、カテゴリ ID 1 のすべてのブログ投稿を返します。

注: クエリ スコープは連鎖できるため、複数のクエリ スコープを同時に使用して、より正確な結果を取得できます。

  1. クエリ スコープのグローバル定義

モデル全体で同じクエリ スコープを使用する場合は、グローバル クエリ スコープを定義できます。これを行うには、モデル内でブート メソッドを呼び出し、static::addGlobalScope メソッドを使用してグローバル クエリ スコープを定義するだけです。

次に、基本的なグローバル クエリ スコープの例を示します。

protected static function boot()
{
    parent::boot();

    static::addGlobalScope('active', function (Builder $builder) {
        $builder->where('active', '=', 1);
    });
}

上の例では、active という名前のグローバル クエリ スコープを定義し、それを 1 レコードに等しいアクティブ フィールドに制限します。

これで、任意のメソッドでモデルをクエリすると、クエリ スコープが自動的に有効になります。

  1. クエリ スコープの削除

特定のモデルのクエリ スコープを削除する必要がある場合があります。 Laravel は、これを実現するために、removeGlobalScope メソッドを提供します。

たとえば、active という名前のグローバル クエリ スコープがあると仮定すると、次のメソッドを使用してそれを削除できます。

$users = User::withoutGlobalScope('active')->get();

上記のコードは、アクティブなクエリ スコープによって制限されていないすべてのクエリを返します。スコープユーザー。

注: すべてのグローバル クエリ スコープを削除する場合は、withoutGlobalScopes メソッドを使用できます。

$users = User::withoutGlobalScopes()->get();

上記のコードは、グローバル クエリ スコープによって制限されていないすべてのユーザーを返します。

概要

クエリスコープは、Laravel の非常に強力な機能です。クエリ スコープを使用すると、アプリケーション全体で一般的なクエリ操作を簡単に再利用でき、コードをより明確に整理できます。クエリ スコープの正しい使用法を学ぶと、生産性が向上するだけでなく、より堅牢なアプリケーションを構築するのにも役立ちます。

以上がlaravelクエリスコープの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
インクルージョンの幻想:リモートワークにおける孤立と孤独への対処インクルージョンの幻想:リモートワークにおける孤立と孤独への対処Apr 25, 2025 am 12:28 AM

トコンバティソルメントアンドロネリネスは、レモであり、regultionを実現し、等間grothopportunitionを提供し、効率的に使用します

フルスタック開発のためのLaravel:包括的なガイドフルスタック開発のためのLaravel:包括的なガイドApr 25, 2025 am 12:27 AM

laravelispopopularfulfull-stackdevelopment becuseiTOfferseamlessbbackEndpowendPowerandfflexibility.1)simplifyDatabaseItteractions.2)asbladetemplatingEngineallowsforclean、dynamictmltemplates.3)Laravelmix

ビデオ会議対決:リモート会議に適したプラットフォームを選択するビデオ会議対決:リモート会議に適したプラットフォームを選択するApr 25, 2025 am 12:26 AM

ビデオ会議プラットフォームを選択する際の重要な要因には、ユーザーインターフェイス、セキュリティ、および機能が含まれます。 1)ズームなど、ユーザーインターフェイスは直感的である必要があります。 2)セキュリティに注意を払う必要があり、Microsoftチームはエンドツーエンドの暗号化を提供します。 3)機能は要件を一致させる必要があり、Googlemeetは短い会議に適しており、Ciscowebexは高度なコラボレーションツールを提供します。

最新のLaravelと互換性のあるデータベースバージョンは何ですか?最新のLaravelと互換性のあるデータベースバージョンは何ですか?Apr 25, 2025 am 12:25 AM

Laravel10の最新バージョンは、MySQL 5.7以降、PostgreSQL 9.6以降、SQLite 3.8.8以降、SQLServer 2017以降と互換性があります。これらのバージョンは、クエリとストレージの効率を向上させるMySQL5.7のJSONデータ型など、LaravelのORM機能をサポートするため選択されます。

Laravelをフルスタックのフレームワークとして使用することの利点Laravelをフルスタックのフレームワークとして使用することの利点Apr 25, 2025 am 12:24 AM

laravelisanexcellentchoicefulfulffull stackdevelopmentduetoitsotsobustfeaturesofuse.1)そのImprifiescomplextaskswithnphpsynthenphpsynpsuls likebladeforfront-dandeloquentormforback-end.2)laravelmixandartisantystemを拡張するlaravedecosystem

Laravelの最新バージョンは何ですか?Laravelの最新バージョンは何ですか?Apr 24, 2025 pm 05:17 PM

laravel10、releaseonfebruary7,2023、isThelateStversion.itfeatures:1)改善された改善とnewReportmethexceptionhandler、2)拡張サプロポートフォーフプP8.1FeatureslikeNums、and3)

最新のLaravelバージョンはどのように開発を簡素化しますか?最新のLaravelバージョンはどのように開発を簡素化しますか?Apr 24, 2025 pm 05:01 PM

ThelatestlaravelversionEnhancesDevelopments:1)SimplifiedRoutingImplicitModelbinding、2)EnhancedEloquentCapabilitiesWithNewQueryMethods、and3)supportformdernphpeaturesliekenamedarguments、makedingdingingindenjoyableを改善しました。

最新のLaravelバージョンのリリースノートはどこにありますか?最新のLaravelバージョンのリリースノートはどこにありますか?Apr 24, 2025 pm 04:53 PM

laravel.com/docsで最新のLaravelバージョンのリリースノートを見つけることができます。 1)リリースノート新しい機能、バグの修正、改善に関する詳細情報を提供します。 2)新しい機能の適用を理解するのに役立つ例と説明が含まれています。 3)新機能の潜在的な複雑さと後方互換性の問題に注意してください。 4)リリースノートの定期的なレビューは、それを更新し続け、イノベーションを刺激することができます。

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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境