3 use Illuminate\Database\Migrations\Migration;
4 use Illuminate\Database\Schema\Blueprint;
5 use Illuminate\Support\Facades\DB;
6 use Illuminate\Support\Facades\Schema;
8 return new class extends Migration
13 public function up(): void
15 Schema::table('pages', function (Blueprint $table) {
16 $table->integer('revision_count');
18 Schema::table('page_revisions', function (Blueprint $table) {
19 $table->integer('revision_number');
20 $table->index('revision_number');
23 // Update revision count
24 $pTable = DB::getTablePrefix() . 'pages';
25 $rTable = DB::getTablePrefix() . 'page_revisions';
26 DB::statement("UPDATE {$pTable} SET {$pTable}.revision_count=(SELECT count(*) FROM {$rTable} WHERE {$rTable}.page_id={$pTable}.id)");
30 * Reverse the migrations.
32 public function down(): void
34 Schema::table('pages', function (Blueprint $table) {
35 $table->dropColumn('revision_count');
37 Schema::table('page_revisions', function (Blueprint $table) {
38 $table->dropColumn('revision_number');