6
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Laravelでのデータベースの利用方法

Posted at

データベース利用の主な方法

  • DBクラス(SQLクエリを直接実行)
  • DBクラス(クエリビルダ)
  • Eloquent

以上の3つが代表的な利用方法です!
1つずつ説明していきます!

DBクラス(SQLクエリを直接実行)

SQLを扱えるのであればこの方法は抵抗なく利用することができるでしょう!
早速サンプルコードを見ていきます

SELECT文

$users = DB::select('select * from users');

ここで使っているDB::selectというのがデータベースからデータを取り出す処理です。
DB::selectはSQLクエリを実行して結果となるレコードを取得するものです。引数には実行するSQLのクエリ文を文字列として用意しておきます!

INSERT文

public fuction create(Request $request)
{
    $param = [
        'name' => $request->name,
        'age' => $request->age,
        'mail' => $request->mail,
    ];
    DB::insert('insert into users(name, age, mail) values(:name, :age, :mail)', $param);

    return redirect('/home');
}

ここでは、送信されたフォームの内容をもとにレコードを作成をしています。まず$paramにフォームの値を保管します。
後は、この配列をパラメータ引数にして、DB::insertを呼び出して実行しています!

このようにSQL文をある程度扱える方であればLaravelでもSQL文を作成してデータベースとのやりとりが可能となっています!

ただこの方法はあまり使われていない印象です。SQLが分かっていれば簡単ですが、何より「バグが紛れ込みやすい」という欠点があります。渡される値の内容によっては予想外のSQL文が実行されてしまう危険があります。

ということで他の方法も見ていきましょう!

クエリビルダ

DBクラスにはクエリビルダと呼ばれる機能が用意されています。メソッドチェーンを使ってデータベースアクセスが行えるようになります。
「クエリビルダ」とはSQLのクエリ文を生成するために用意された一連のメソッドです。メソッドチェーンとして連続して呼び出していくことで、クエリ文を内部で生成して実行することができます!

$users = DB::table('users')->get();

このDB::tableは指定したテーブルの「ビルダ」を取得します。
get()はSQLのselect文に相当するものと考えてください!

$users = DB::table('users')
    ->where('name', 'いしかわ')
    ->orWhere('name', 'おかばやし')
    ->get();

where()はSQLのwhere句に該当するものです。引数にカラム名と値を指定することで条件に合致するデータを取得します。
whereメソッドに3つの引数を持たせて、呼び出すこともできます。

$users = DB::table('users')
    ->where('id', '<=', '10')
    ->get();

こうすることによってid10以下のデータに絞って取得することができます!

insert文

$param = [
    'name' => ひらた,
    'age' => 34,
    'mail' => hirata@gmail.com
];
$users = DB::table('users')->insert($param)

このようにクエリビルダを利用すれば直接SQL文を作成しなくてもデータを取得したり、データの新規作成ができたりします!

Eloquent

LaravelにはEloquentというものが用意されています。「モデル」と呼ばれるクラスを定義して、これを利用してデータベース操作を行うように設計されています。「モデル」とはテーブルの内容を定義したクラスです。
usersテーブルに紐づくUserモデルを作成してみましょう!

php artisan make:model User

このコマンドを打つことによってapp/配下にUser.phpというファイルが作成され、usersテーブルUserモデルが紐づくことになります。
このUserモデルを他のファイルで利用するにはuseしてあげる必要があります。

use App\User;

Userモデルで全レコードを取得

$users = User::all();

これだけでusersテーブルから全レコードを取得することができます。
SQLを一切使わずにデータベースを利用できて直感的でわかりやすいですよね!
また、Eloquentもクエリビルダ同様メソッドチェーンを利用してデータベースアクセスができます。

$users = User::where('age', 36)
    ->where('name', 'おおしま')
    ->first();

新規作成

$user = new User;
$user->name = 'やなぎ';
$user->age = 28;
$user->mail = 'yanagi@gmail.com';
$user->save();

更新

$user = User->find($request->id);
$user->name = 'おがさわら';
$user->age = 24;
$user->mail = 'ogasawara@gmail.com';
$user->save();

削除

$user = User->find($request->id)->delete();

まとめ

このようにSQLを書かなくてもデータベースのとやりとりができてとても便利ですね!
LaravelにはEloquentがあるからSQLの知識はなくてもいいと思うかもしれませんが個人的にはSQLの知識は必須だと思います。その理由はEloquentを使ってデータを取得した際に、もしエラーになったら結局SQL文をみてどこが間違っているのかを探すからです。この時SQLがわからなければエラーを解消することはできません。
Laravelを使うときも基本的なSQLの知識は身につけておきましょう!
基本的にはLaravelではEloquentを使うことを推奨しますが、Eloquentのデメリットもありまして、取得するデータ量が大容量の時には処理速度が遅くなることがあります。その際にはクエリビルダを利用することをお勧めします!クエリビルだの方が処理速度が少し速くなります。

この記事は以下の書籍を参考に執筆しました。
PHPフレームワークLaravel入門 第2版

余談

$posts = Post::where('title', 'Laravel')
    ->where('body', 'like', '%' . $keyword . '%')
    ->orderBy('id', 'asc')
    ->limit(5)
    ->get();

上記のようなコードの場合個人的にはquery()を使って条件部分のインデントを揃えて可読性をあげるようにしています。

$posts = Post::query()
    ->where('title', 'Laravel')
    ->where('body', 'like', '%' . $keyword . '%')
    ->orderBy('id', 'asc')
    ->limit(5)
    ->get();

query()を使うのは割と少数派のようですが、、、

一応query()を使うメリットもありまして、
バッチ処理でデータ更新をするときには

$posts = Post::update(['title' => '更新']);

上記では出来なくて

$posts = Post::query()->update(['title' => '更新']);

query()を使うとできるみたいです!
他にもquery()を使うメリットがあるみたいなのでquery()派が多数派になっていくかもしれません。

6
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
6
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?