90 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
<?php
 | 
						|
 | 
						|
use Illuminate\Database\Migrations\Migration;
 | 
						|
use Illuminate\Database\Schema\Blueprint;
 | 
						|
 | 
						|
class AddEntityIndexes extends Migration
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * Run the migrations.
 | 
						|
     *
 | 
						|
     * @return void
 | 
						|
     */
 | 
						|
    public function up()
 | 
						|
    {
 | 
						|
        Schema::table('books', function (Blueprint $table) {
 | 
						|
            $table->index('slug');
 | 
						|
            $table->index('created_by');
 | 
						|
            $table->index('updated_by');
 | 
						|
        });
 | 
						|
        Schema::table('pages', function (Blueprint $table) {
 | 
						|
            $table->index('slug');
 | 
						|
            $table->index('book_id');
 | 
						|
            $table->index('chapter_id');
 | 
						|
            $table->index('priority');
 | 
						|
            $table->index('created_by');
 | 
						|
            $table->index('updated_by');
 | 
						|
        });
 | 
						|
        Schema::table('page_revisions', function (Blueprint $table) {
 | 
						|
            $table->index('page_id');
 | 
						|
        });
 | 
						|
        Schema::table('chapters', function (Blueprint $table) {
 | 
						|
            $table->index('slug');
 | 
						|
            $table->index('book_id');
 | 
						|
            $table->index('priority');
 | 
						|
            $table->index('created_by');
 | 
						|
            $table->index('updated_by');
 | 
						|
        });
 | 
						|
        Schema::table('activities', function (Blueprint $table) {
 | 
						|
            $table->index('book_id');
 | 
						|
            $table->index('user_id');
 | 
						|
            $table->index('entity_id');
 | 
						|
        });
 | 
						|
        Schema::table('views', function (Blueprint $table) {
 | 
						|
            $table->index('user_id');
 | 
						|
            $table->index('viewable_id');
 | 
						|
        });
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Reverse the migrations.
 | 
						|
     *
 | 
						|
     * @return void
 | 
						|
     */
 | 
						|
    public function down()
 | 
						|
    {
 | 
						|
        Schema::table('books', function (Blueprint $table) {
 | 
						|
            $table->dropIndex('books_slug_index');
 | 
						|
            $table->dropIndex('books_created_by_index');
 | 
						|
            $table->dropIndex('books_updated_by_index');
 | 
						|
        });
 | 
						|
        Schema::table('pages', function (Blueprint $table) {
 | 
						|
            $table->dropIndex('pages_slug_index');
 | 
						|
            $table->dropIndex('pages_book_id_index');
 | 
						|
            $table->dropIndex('pages_chapter_id_index');
 | 
						|
            $table->dropIndex('pages_priority_index');
 | 
						|
            $table->dropIndex('pages_created_by_index');
 | 
						|
            $table->dropIndex('pages_updated_by_index');
 | 
						|
        });
 | 
						|
        Schema::table('page_revisions', function (Blueprint $table) {
 | 
						|
            $table->dropIndex('page_revisions_page_id_index');
 | 
						|
        });
 | 
						|
        Schema::table('chapters', function (Blueprint $table) {
 | 
						|
            $table->dropIndex('chapters_slug_index');
 | 
						|
            $table->dropIndex('chapters_book_id_index');
 | 
						|
            $table->dropIndex('chapters_priority_index');
 | 
						|
            $table->dropIndex('chapters_created_by_index');
 | 
						|
            $table->dropIndex('chapters_updated_by_index');
 | 
						|
        });
 | 
						|
        Schema::table('activities', function (Blueprint $table) {
 | 
						|
            $table->dropIndex('activities_book_id_index');
 | 
						|
            $table->dropIndex('activities_user_id_index');
 | 
						|
            $table->dropIndex('activities_entity_id_index');
 | 
						|
        });
 | 
						|
        Schema::table('views', function (Blueprint $table) {
 | 
						|
            $table->dropIndex('views_user_id_index');
 | 
						|
            $table->dropIndex('views_viewable_id_index');
 | 
						|
        });
 | 
						|
    }
 | 
						|
}
 |