カテゴリ: Laravel 更新日: 2025/11/01

LaravelのEloquentでwhere句・orderByを使った検索方法を徹底解説!初心者でも理解できるデータ検索入門

LaravelのEloquentでwhere句やorderByを使った検索方法
LaravelのEloquentでwhere句やorderByを使った検索方法

先生と生徒の会話形式で理解しよう

生徒

「Laravelでデータベースから条件に合うデータだけを取り出す方法はありますか?」

先生

「あります。Eloquent ORMのwhere句を使うと、簡単に条件付き検索ができます。」

生徒

「where句って、SQLのWHEREと同じ意味ですか?」

先生

「その通りです。EloquentではSQLを書かなくても、PHPのコードだけで同じ検索条件を作れます。」

生徒

「順番に並べたい場合もできますか?」

先生

「はい、orderByを使えば、昇順や降順に並べ替えも簡単です。」

1. where句とは?

1. where句とは?
1. where句とは?

Eloquentのwhereは、データベースから条件に合うレコードを絞り込むためのメソッドです。例えば「年齢が20歳以上のユーザーだけを取得する」といった操作が可能です。SQLでいうWHERE句と同じ働きを持ちます。

where句を使うと、必要なデータだけを取得できるため、処理が効率的になり、アプリの表示速度も速くなります。

2. 基本的なwhere句の使い方

2. 基本的なwhere句の使い方
2. 基本的なwhere句の使い方

例えばユーザー情報を格納したusersテーブルから「名前が田中のユーザー」を取得したい場合、Eloquentでは次のように書きます。


use App\Models\User;

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

このコードではget()を使って、条件に合うすべてのユーザー情報を取得しています。

3. 複数条件の検索

3. 複数条件の検索
3. 複数条件の検索

複数の条件を組み合わせて検索することもできます。例えば「名前が田中で年齢が20歳以上」のユーザーを取得したい場合は次の通りです。


$users = User::where('name', '田中')
             ->where('age', '>=', 20)
             ->get();

このようにwhereを連続して書くことで、条件をANDでつなぐことができます。

4. orderByで並べ替え

4. orderByで並べ替え
4. orderByで並べ替え

取得したデータを順番に並べたい場合はorderByを使います。例えば年齢の昇順で並べる場合は次のように書きます。


$users = User::where('age', '>=', 20)
             ->orderBy('age', 'asc')
             ->get();

逆に降順にしたい場合はdescを指定します。


$users = User::where('age', '>=', 20)
             ->orderBy('age', 'desc')
             ->get();

このようにorderByを使うと、データを希望する順序で取得でき、一覧表示などに便利です。

5. 初心者でも理解しておくと便利なポイント

5. 初心者でも理解しておくと便利なポイント
5. 初心者でも理解しておくと便利なポイント

EloquentのwhereorderByは、SQLを書かなくてもデータベース検索ができる便利な仕組みです。プログラミング初心者でも、少しずつ条件を追加したり順序を指定するだけで複雑な検索が可能になります。

実際の開発現場では、ユーザー検索や商品検索、ブログ記事の一覧表示などで頻繁に使われます。最初は簡単な条件検索から始めて、慣れてきたら複数条件や並べ替えを組み合わせて活用すると良いでしょう。

また、Eloquentのメソッドチェーンを使うことで、複数の条件や並べ替えを一つのコードでまとめられるので、コードもすっきり書けます。

関連記事:
カテゴリの一覧へ
新着記事
New1
Laravel
Laravelの認証状態をチェックする方法を完全解説!authとAuth::check()を初心者向けにやさしく説明
New2
CodeIgniter
CodeIgniterのコントローラクラスの作り方を完全ガイド!初心者でもわかる基礎から実践まで
New3
Symfony
Symfonyのフォームラベルを多言語対応!初心者でもわかる翻訳設定ガイド
New4
Laravel
Laravelでユーザー登録機能を作る方法!初心者向けにバリデーションとリダイレクトをやさしく解説
人気記事
No.1
Java&Spring記事人気No1
Laravel
Laravelのデータベース設定方法を完全ガイド!初心者でもわかる.envファイルの使い方
No.2
Java&Spring記事人気No2
Laravel
Laravelのビューとは?Bladeテンプレートの基本を解説
No.3
Java&Spring記事人気No3
Laravel
Laravelでセッションを扱う方法!保存方法と利用例を解説
No.4
Java&Spring記事人気No4
Laravel
Laravelのルート一覧を確認する方法!初心者でもわかるphp artisan route:listの使い方
No.5
Java&Spring記事人気No5
Laravel
Laravelでルーティングを設定する方法!web.phpと基本ルートの書き方を初心者向けに徹底解説
No.6
Java&Spring記事人気No6
Laravel
Laravelでログを出力する方法(Monolog・storage/logs)
No.7
Java&Spring記事人気No7
Laravel
Laravelのルートキャッシュ機能を活用してパフォーマンス改善!初心者でもわかる完全ガイド
No.8
Java&Spring記事人気No8
Laravel
LaravelでルートをBladeテンプレートに記述する方法(route関数)