20220718230909_start_migration.php 2,4 КБ
Newer Older
Иванов Игорь Антонович's avatar
Иванов Игорь Антонович включено в состав коммита
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
<?php

use Phinx\Db\Adapter\PostgresAdapter;
use Phinx\Migration\AbstractMigration;

class StartMigration extends AbstractMigration
{
    /**
     * Change Method.
     *
     * Write your reversible migrations using this method.
     *
     * More information on writing migrations is available here:
     * http://docs.phinx.org/en/latest/migrations.html#the-abstractmigration-class
     *
     * The following commands can be used in this method and Phinx will
     * automatically reverse them when rolling back:
     *
     *    createTable
     *    renameTable
     *    addColumn
     *    addCustomColumn
     *    renameColumn
     *    addIndex
     *    addForeignKey
     *
     * Any other destructive changes will result in an error when trying to
     * rollback the migration.
     *
     * Remember to call "create()" or "update()" and NOT "save()" when working
     * with the Table class.
     */
    public function change()
    {

	    $table = $this->table('user');

	    $table->addColumn('last_name', PostgresAdapter::PHINX_TYPE_STRING)
	        ->addColumn('first_name', PostgresAdapter::PHINX_TYPE_STRING)
	        ->addColumn('middle_name', PostgresAdapter::PHINX_TYPE_STRING, [ 'null' => true ])
		    ->addColumn('phone', PostgresAdapter::PHINX_TYPE_STRING)
		    ->addColumn('email', PostgresAdapter::PHINX_TYPE_STRING, [ 'null' => true ])
		    ->addColumn('login', PostgresAdapter::PHINX_TYPE_STRING, [ 'null' => true ])
		    ->addColumn('password', PostgresAdapter::PHINX_TYPE_STRING, [ 'null' => true ])
		    ->addColumn('avatar', PostgresAdapter::PHINX_TYPE_STRING, [ 'null' => true ])
		    ->addColumn('birth_date', PostgresAdapter::PHINX_TYPE_DATETIME, [ 'null' => true ])
		    ->addColumn('passport_data', PostgresAdapter::PHINX_TYPE_JSONB, [ 'null' => true ])
		    ->addColumn('driver_license_data', PostgresAdapter::PHINX_TYPE_JSONB, [ 'null' => true ])
		    ->addColumn('comment', PostgresAdapter::PHINX_TYPE_TEXT, [ 'null' => true ])
		    ->addColumn('is_change_password', PostgresAdapter::PHINX_TYPE_INTEGER)
		    ->addColumn('type', PostgresAdapter::PHINX_TYPE_INTEGER)
		    ->addColumn('status', PostgresAdapter::PHINX_TYPE_INTEGER)
		    ->addColumn('created_at', PostgresAdapter::PHINX_TYPE_DATETIME)
		    ->addColumn('updated_at', PostgresAdapter::PHINX_TYPE_DATETIME, [ 'null' => true ]);

	    $table->addIndex([ 'phone', 'email', 'login' ]);

	    $table->create();

    }
}