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


こんな悩みを解決できる記事を書きました!
僕は現役フリーランスエンジニア(歴10年)で、資格は13個保有しています。
「Laravelでロック用のテーブルを用意してテーブルロックする方法を知りたい」とお考えではありませんか?
Laravelでテーブルをロックする際、ロック用のテーブルを用意しておけば不測の事態が起きても被害を最小限にできます。



ということで、ロック用のテーブル作成方法とロック方法について解説します。
こんな記事、誰に需要あんねん。
ちなみに、DBはPostgresです。
ということで、本記事ではLaravelでロック用のテーブルを用意してテーブルロックする方法を解説します。





すぐ読み終わるので、ぜひ最後まで読んでくださいませ。
【当サイト】おすすめフリーランスエージェント3選 | |||
---|---|---|---|
エージェント | 評価 | ポイント | 公式サイト |
![]() ![]() レバテックフリーランス ![]() ![]() | 5.0 | 業界最大級のエージェント。 高単価案件が豊富。 | 公式 |
![]() ![]() Midworks ![]() ![]() | 4.8 | 満足度調査で 3年連続3冠を達成。 | 公式 |
![]() ![]() ITプロパートナーズ ![]() ![]() | 4.6 | 週2〜3向けの案件が豊富。 | 公式 |
【Laravel】ロック用のテーブルでテーブルロックする方法
誰も興味ないと思いますが、Laravelでロック用のテーブルを用意してテーブルロックする方法を解説します。
マイグレーションファイルの作成
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');
}
};
マイグレーションファイルを作成し、ロック用のテーブルとデータを登録します。



データは処理毎に登録するイメージです。
ロック用テーブルでロックする
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つのエージェントを使い回していますよ。
フリーランスを始めるなら「レバテックフリーランス


」

- 業界最大級の案件数。
- 業界トップクラスの高単価報酬、低マージン(平均年収862万円)。
- 案件参画中のフォローの充実。
※詳細は「【業界最大手】レバテックフリーランスとは?メリットや利用手順を解説!」を参照。
レバテックフリーランス
とにかく案件数が多いので、とりあえず登録しておけば間違いないエージェントです!



僕もはじめてフリーランスの案件を貰ったのはレバテックフリーランス
保有している案件数が多いので、業務経験がなくても何かしらの案件は紹介してもらえますよ(僕はJavaの経験3年でも案件を貰えました)。
手厚い保障を重視したいなら「Midworks


」

- 手厚い保障で正社員並みの安心感。
- 還元率60%超え&単価公開でクリアな契約。
- 給与保障制度(審査あり)。
Midworks
フリーランスを目指しているけど不安な方や保障を重視したい方におすすめです。



僕も何度か案件を紹介してもらいました。
自分のスキルに合った案件を紹介してもらえましたし、電話のやり取りも非常に丁寧でした。
週2〜3日の案件探しなら「ITプロパートナーズ


」

- IT案件に特化したフリーランスエージェント。
- 週2〜3日の案件が豊富。
- リモート案件が多く、直エンドなので単価も高い。
※詳細は「【週2・3案件】ITプロパートナーズとは?メリットや利用手順を解説!」を参照。
ITプロパートナーズ
週2〜3日から参画できる案件が豊富なので、起業したい人にもおすすめです。



週2〜3日の案件はある程度スキルがないと紹介してもらえない印象です。
とはいえ、週5の案件ももちろんありますし、僕が利用した時は迅速・丁寧に対応していただきました!
まとめ
今回は、Laravelでロック用のテーブルを用意してテーブルロックする方法について解説しました。
以下が本記事のまとめになります。
- おすすめ本
Laravelの勉強なら「PHPフレームワーク Laravel入門 第2版



最後までお読みいただき、ありがとうございました!
【当サイト】おすすめフリーランスエージェント3選 | |||
---|---|---|---|
エージェント | 評価 | ポイント | 公式サイト |
![]() ![]() レバテックフリーランス ![]() ![]() | 5.0 | 業界最大級のエージェント。 高単価案件が豊富。 | 公式 |
![]() ![]() Midworks ![]() ![]() | 4.8 | 満足度調査で 3年連続3冠を達成。 | 公式 |
![]() ![]() ITプロパートナーズ ![]() ![]() | 4.6 | 週2〜3向けの案件が豊富。 | 公式 |
- クソおすすめ本



海外のエンジニアがどういった思考で働いているかが理解できます。
海外に行く気はないけど海外エンジニアの動向が気になる雑魚エンジニアにおすすめです(本当におすすめな本しか紹介しないのでご安心を)。
- 他サイトも見てね