48 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <?php
 | |
| declare(strict_types=1);
 | |
| 
 | |
| use Migrations\AbstractMigration;
 | |
| 
 | |
| class CreateProducts extends AbstractMigration
 | |
| {
 | |
|     /**
 | |
|      * Change Method.
 | |
|      *
 | |
|      * More information on this method is available here:
 | |
|      * https://book.cakephp.org/phinx/0/en/migrations.html#the-change-method
 | |
|      * @return void
 | |
|      */
 | |
|     public function change(): void
 | |
|     {
 | |
|         $table = $this->table('products', ['id' => false, 'primary_key' => ['id']]);
 | |
|         $table->addColumn('id', 'uuid', [
 | |
|             'default' => null,
 | |
|             'null' => false,
 | |
|         ]);
 | |
|         $table->addColumn('name', 'string', [
 | |
|             'default' => null,
 | |
|             'limit' => 255,
 | |
|             'null' => false,
 | |
|         ]);
 | |
|         $table->addColumn('product_category_id', 'uuid', [
 | |
|             'default' => null,
 | |
|             'null' => false,
 | |
|         ]);
 | |
|         $table->addColumn('product_type_id', 'integer', [
 | |
|             'default' => null,
 | |
|             'limit' => 11,
 | |
|             'null' => false,
 | |
|         ]);
 | |
|         $table->addIndex('product_category_id');
 | |
|         $table->addIndex('product_type_id');
 | |
|         $table->addIndex([
 | |
|             'product_category_id',
 | |
|             'name',
 | |
|         ], [
 | |
|             'name' => 'BY_NAME_AND_CATEGORY_ID',
 | |
|             'unique' => true,
 | |
|         ]);
 | |
|         $table->create();
 | |
|     }
 | |
| }
 |