{category}

Laravel - クエリスコープ

scopeActive()

スコープアクティブ(Eloquent ORM とデータベース操作

意味 アクティブな要素を絞り込む


scopeActive()とは?

scopeActive()は、クエリスコープの一種で、アクティブな状態の要素だけを簡単に取得できるようにするメソッドです。モデルに定義することで、複数の場所で同じ条件を使いやすくなります。

scopeActive()の具体的な使い方

アクティブな商品を取得する例

use App\Models\Product;

class Product extends Model
{
    public function scopeActive($query)
    {
        return $query->where('is_active', true);
    }
}

// コントローラーやサービスクラスでの使用例
$activeProducts = Product::active()
    ->where('stock', '>', 0)
    ->orderBy('price', 'asc')
    ->get();

foreach ($activeProducts as $product) {
    echo "商品名: {$product->name}, 価格: {$product->price}円\n";
}

👇出力結果

商品名: Tシャツ, 価格: 2000円
商品名: ジーンズ, 価格: 5000円
商品名: スニーカー, 価格: 8000円
商品名: バッグ, 価格: 12000円

この例では、ProductモデルにscopeActive()を定義し、アクティブな商品のみを簡単に取得できるようにしています。コントローラーやサービスクラスで、active()メソッドを呼び出すことで、アクティブな商品を取得し、さらに在庫がある商品を価格の安い順に並べて表示しています。

scopeActive()に関するよくある質問

Q. クエリスコープとは何ですか?
A. クエリスコープは、頻繁に使用するクエリの一部を再利用可能な形で定義する機能です。これにより、コードの重複を減らし、クエリの一貫性を保つことができます。
Q. スコープの名前の規則は?
A. スコープメソッドの名前は必ず'scope'で始まる必要があります。ただし、使用時には'scope'を省略して呼び出します。例えば、scopeActive()は使用時にactive()となります。
Q. 複数のスコープを組み合わせられる?
A. はい、複数のスコープを組み合わせることができます。例えば、User::active()->popular()->get()のように、複数のスコープをチェーンすることが可能です。

scopeActive()が学べる書籍の紹介

「プログラミング単語帳」を使って、プログラミングの単語を英単語のように学習してみませんか?
プログラミング単語帳には、LaravelのscopeActive()やdelete()、skip()、scopePopular()、などのような実務でよく使われる単語が数百以上収録されています。
この書籍には、プログラミングの単語の意味や読み方、単語の使い方がわかる例文などが掲載されており、いつでもどこでもプログラミングの学習ができます。

よく使われる単語にだけ絞って学習することができるので、効率的にプログラミングが学習できます。

1日5分の暗記でプログラミンが身に付く!プログラミング単語帳 公式ストアで発売中!

HTML編、CSS編、JavaScript編、PHP編、Ruby編、その他単語編の6シリーズ分が公式ストアにて販売中です。気になった方はぜひ購入してみてください。


Laravelを学べる「プログラミング単語帳」アプリ

プログラミング単語帳がアプリになりました!Laravelはもちろん、10種類のプログラミング言語の中から、よく使われる単語をスマホで学習できます。

収録単語は2,000単語以上!
現在は、HTML、CSS、JavaScirpt、PHP、Laravel、Ruby、Python、MySQL、Linux、など10カテゴリーの単語帳が1つのアプリに収録されています。

いつでも、どこでも、隙間時間を有効活用して、プログラミングを効率的に学べるので、ぜひダウンロードしてみてください。

2024年7月アップデート情報:「Laravel」カテゴリーが追加されましました!

2024年8月アップデート情報:「MySQL」「Linux」カテゴリーが追加されましました!


関連するそのほかの単語

delete()

レコードを削除

種類: データ操作

skip()

指定数のレコードを省略

種類: 高度なクエリ

scopePopular()

人気のある要素を絞り込む

種類: クエリスコープ

asset()

アセットファイルのURLを生成

種類: アプリケーション

Route::view()

直接ビューを表示

種類: 高度なルーティング