yii2

Форк
1
/
m150207_210500_i18n_init.php 
57 строк · 1.9 Кб
1
<?php
2
/**
3
 * @link https://www.yiiframework.com/
4
 * @copyright Copyright (c) 2008 Yii Software LLC
5
 * @license https://www.yiiframework.com/license/
6
 */
7

8
use yii\db\Migration;
9

10
/**
11
 * Initializes i18n messages tables.
12
 *
13
 *
14
 *
15
 * @author Dmitry Naumenko <d.naumenko.a@gmail.com>
16
 * @since 2.0.7
17
 */
18
class m150207_210500_i18n_init extends Migration
19
{
20
    public function up()
21
    {
22
        $tableOptions = null;
23
        if ($this->db->driverName === 'mysql') {
24
            // https://stackoverflow.com/questions/766809/whats-the-difference-between-utf8-general-ci-and-utf8-unicode-ci
25
            $tableOptions = 'CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE=InnoDB';
26
        }
27

28
        $this->createTable('{{%source_message}}', [
29
            'id' => $this->primaryKey(),
30
            'category' => $this->string(),
31
            'message' => $this->text(),
32
        ], $tableOptions);
33

34
        $this->createTable('{{%message}}', [
35
            'id' => $this->integer()->notNull(),
36
            'language' => $this->string(16)->notNull(),
37
            'translation' => $this->text(),
38
        ], $tableOptions);
39

40
        $this->addPrimaryKey('pk_message_id_language', '{{%message}}', ['id', 'language']);
41
        $onUpdateConstraint = 'RESTRICT';
42
        if ($this->db->driverName === 'sqlsrv') {
43
            // 'NO ACTION' is equivalent to 'RESTRICT' in MSSQL
44
            $onUpdateConstraint = 'NO ACTION';
45
        }
46
        $this->addForeignKey('fk_message_source_message', '{{%message}}', 'id', '{{%source_message}}', 'id', 'CASCADE', $onUpdateConstraint);
47
        $this->createIndex('idx_source_message_category', '{{%source_message}}', 'category');
48
        $this->createIndex('idx_message_language', '{{%message}}', 'language');
49
    }
50

51
    public function down()
52
    {
53
        $this->dropForeignKey('fk_message_source_message', '{{%message}}');
54
        $this->dropTable('{{%message}}');
55
        $this->dropTable('{{%source_message}}');
56
    }
57
}
58

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.