【Laravel】ロック用のテーブルでテーブルロックする方法!

当ページのリンクには広告が含まれています。
【Laravel】ロック用のテーブルでテーブルロックする方法
いずみ

こんな悩みを解決できる記事を書きました!

僕は現役フリーランスエンジニア(歴年)で、資格は個保有しています。

Laravelでロック用のテーブルを用意してテーブルロックする方法を知りたい」とお考えではありませんか?

Laravelでテーブルをロックする際、ロック用のテーブルを用意しておけば不測の事態が起きても被害を最小限にできます。

いずみ

ということで、ロック用のテーブル作成方法とロック方法について解説します。

こんな記事、誰に需要あんねん。

ちなみに、DBはPostgresです。

ということで、本記事ではLaravelでロック用のテーブルを用意してテーブルロックする方法を解説します。

いずみ

すぐ読み終わるので、ぜひ最後まで読んでくださいませ。

スクロールできます
【当サイト】おすすめフリーランスエージェント3選
エージェント評価ポイント公式サイト
レバテックフリーランス

5.0
業界最大級のエージェント。
高単価案件が豊富。
公式
Midworks

4.8
満足度調査で
3年連続3冠を達成。
公式
ITプロパートナーズ

4.6
週2〜3向けの案件が豊富。公式
執筆者/監修者
  • フリーランスエンジニア(保有資格個、企業と直接契約
  • ブログ・アフィリエイト歴7年(2018年〜)
  • ブランドせどりで月利50万円⇨脱サラ
  • 投資(仮想通貨・FX)歴7年(2018年〜)
  • X(旧Twitter)フォロワー約1,900人
  • 運営者情報はこちら
いずみです
目次

【Laravel】ロック用のテーブルでテーブルロックする方法

誰も興味ないと思いますが、Laravelでロック用のテーブルを用意してテーブルロックする方法を解説します。

STEP

マイグレーションファイルの作成

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
use Illuminate\Support\Facades\DB;

return new class extends Migration {
    public function up(): void
    {
        Schema::create('process_locks', function (Blueprint $table) {
            $table->id();
            $table->string('name')->unique();
            $table->timestamps();
        });

        // 初期データを挿入
        DB::table('process_locks')->insert([
            ['name' => 'user_balance_update', 'created_at' => now(), 'updated_at' => now()],
            ['name' => 'order_processing', 'created_at' => now(), 'updated_at' => now()],
            // 他の処理があれば追加
        ]);
    }

    public function down(): void
    {
        Schema::dropIfExists('process_locks');
    }
};

マイグレーションファイルを作成し、ロック用のテーブルとデータを登録します。

いずみ

データは処理毎に登録するイメージです。

STEP

ロック用テーブルでロックする

DB::beginTransaction();

try {
    DB::statement("SET LOCAL idle_in_transaction_session_timeout = '30s'");

    // 処理ごとのロック
    $lock = DB::table('process_locks')
        ->where('name', 'user_balance_update')
        ->lockForUpdate()
        ->first();

    // ロックが取れたら安全に処理
    DB::table('users')
        ->where('id', 1)
        ->update([
            'balance' => DB::raw('balance + 100'),
            'updated_at' => now(),
        ]);

    DB::commit();

} catch (Throwable $e) {
    if (DB::transactionLevel() > 0) {
        DB::rollBack();
    }
    throw $e;
}

ロック用のテーブルを悲観ロックした上で処理します。

いずみ

意外と簡単でしたね。

頭の悪い君でも理解できたかな。

idle_in_transaction_session_timeoutについては「【Laravel】idle_in_transaction_session_timeoutを設定する方法!」で詳しく解説しています。

スクロールできます
【当サイト】おすすめフリーランスエージェント3選
エージェント評価ポイント公式サイト
レバテックフリーランス

5.0
業界最大級のエージェント。
高単価案件が豊富。
公式
Midworks

4.8
満足度調査で
3年連続3冠を達成。
公式
ITプロパートナーズ

4.6
週2〜3向けの案件が豊富。公式

【厳選】フリーランスエンジニアにおすすめなエージェント3選

フリーランスエンジニアになるにはエージェントから案件をもらう必要があります。

僕が実際に利用しているおすすめエージェントを紹介しますね。

いずみ

エージェントは必ず複数登録してください。

担当者によっては「全然案件紹介してくれない…」みたいなこともあるので…

僕は実際に5つのエージェントを使い回していますよ。

フリーランスを始めるなら「

案件数マージン率単価
約88,000件非公開
初心者福利厚生申し込み
無料
Good Point
  • 業界最大級の案件数。
  • 業界トップクラスの高単価報酬、低マージン(平均年収862万円)。
  • 案件参画中のフォローの充実。

※詳細は「【業界最大手】レバテックフリーランスとは?メリットや利用手順を解説!」を参照。

は業界最大手のフリーランスエージェントです。

とにかく案件数が多いので、とりあえず登録しておけば間違いないエージェントです!

いずみ

僕もはじめてフリーランスの案件を貰ったのはです。

保有している案件数が多いので、業務経験がなくても何かしらの案件は紹介してもらえますよ(僕はJavaの経験3年でも案件を貰えました)。

手厚い保障を重視したいなら「

案件数マージン率単価
約10,000件非公開
初心者福利厚生申し込み
無料
Good Point
  • 手厚い保障で正社員並みの安心感。
  • 還元率60%超え&単価公開でクリアな契約。
  • 給与保障制度(審査あり)。

は手厚い保障が特徴のフリーランスエージェントです。

フリーランスを目指しているけど不安な方や保障を重視したい方におすすめです。

いずみ

僕も何度か案件を紹介してもらいました。

自分のスキルに合った案件を紹介してもらえましたし、電話のやり取りも非常に丁寧でした。

週2〜3日の案件探しなら「

案件数マージン率単価
約5,000件非公開
初心者福利厚生申し込み
経験者向け無料
Good Point
  • IT案件に特化したフリーランスエージェント。
  • 週2〜3日の案件が豊富。
  • リモート案件が多く、直エンドなので単価も高い。

※詳細は「【週2・3案件】ITプロパートナーズとは?メリットや利用手順を解説!」を参照。

はIT案件に特化したフリーランスエージェントです。

週2〜3日から参画できる案件が豊富なので、起業したい人にもおすすめです。

いずみ

週2〜3日の案件はある程度スキルがないと紹介してもらえない印象です。

とはいえ、週5の案件ももちろんありますし、僕が利用した時は迅速・丁寧に対応していただきました!

まとめ

今回は、Laravelでロック用のテーブルを用意してテーブルロックする方法について解説しました。

以下が本記事のまとめになります。

まとめ
  • ロック用のテーブルはマイグレーションで作成する。
  • ロック用テーブルのデータをロックすれば安全に処理できる。
まとめ
  • おすすめ本
¥2,673 (2023/07/23 15:53時点 | Amazon調べ)
\楽天ポイント4倍セール!/
楽天市場

Laravelの勉強なら「」が分かりやすくておすすめですよ♪

いずみ

最後までお読みいただき、ありがとうございました!

スクロールできます
【当サイト】おすすめフリーランスエージェント3選
エージェント評価ポイント公式サイト
レバテックフリーランス

5.0
業界最大級のエージェント。
高単価案件が豊富。
公式
Midworks

4.8
満足度調査で
3年連続3冠を達成。
公式
ITプロパートナーズ

4.6
週2〜3向けの案件が豊富。公式
  • クソおすすめ本
¥4,480 (2024/06/01 23:28時点 | Amazon調べ)
\楽天ポイント4倍セール!/
楽天市場
いずみ

海外のエンジニアがどういった思考で働いているかが理解できます。

海外に行く気はないけど海外エンジニアの動向が気になる雑魚エンジニアにおすすめです(本当におすすめな本しか紹介しないのでご安心を)。

  • 他サイトも見てね
【Laravel】ロック用のテーブルでテーブルロックする方法

この記事が気に入ったら
フォローしてね!

シェアしてね!
  • URLをコピーしました!
目次