-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy path1493695462_reconsider_indexes.php
More file actions
111 lines (105 loc) · 3.47 KB
/
1493695462_reconsider_indexes.php
File metadata and controls
111 lines (105 loc) · 3.47 KB
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<?php
/**
* インデックスの見直し
*
* @author Shohei Nakajima <nakajimashouhei@gmail.com>
* @link http://www.netcommons.org NetCommons Project
* @license http://www.netcommons.org/license.txt NetCommons License
* @copyright Copyright 2014, NetCommons Project
*/
App::uses('NetCommonsMigration', 'NetCommons.Config/Migration');
/**
* インデックスの見直し
*
* @author Shohei Nakajima <nakajimashouhei@gmail.com>
* @package NetCommons\Frames\Config\Migration
*/
class ReconsiderIndexes extends NetCommonsMigration {
/**
* Migration description
*
* @var string
*/
public $description = 'reconsider_indexes';
/**
* Actions to be performed
*
* @var array $migration
*/
public $migration = array(
'up' => array(
'alter_field' => array(
'frame_public_languages' => array(
'frame_id' => array('type' => 'integer', 'null' => false, 'default' => null, 'unsigned' => false, 'key' => 'index', 'comment' => 'フレームID'),
'is_public' => array('type' => 'boolean', 'null' => false, 'default' => '1', 'comment' => '公開かどうか'),
),
'frames_languages' => array(
'frame_id' => array('type' => 'integer', 'null' => false, 'default' => null, 'unsigned' => false, 'key' => 'index', 'comment' => 'フレームID'),
'is_translation' => array('type' => 'boolean', 'null' => false, 'default' => '0', 'comment' => '翻訳したかどうか'),
),
),
'drop_field' => array(
'frame_public_languages' => array('indexes' => array('language_id')),
'frames_languages' => array('indexes' => array('language_id')),
),
'create_field' => array(
'frame_public_languages' => array(
'indexes' => array(
'language_id' => array('column' => array('frame_id', 'is_public', 'language_id', 'id'), 'unique' => 0),
),
),
'frames_languages' => array(
'indexes' => array(
'language_id' => array('column' => array('frame_id', 'is_translation', 'language_id', 'id'), 'unique' => 0),
),
),
),
),
'down' => array(
'alter_field' => array(
'frame_public_languages' => array(
'frame_id' => array('type' => 'integer', 'null' => false, 'default' => null, 'unsigned' => false, 'comment' => 'フレームID'),
'is_public' => array('type' => 'boolean', 'null' => false, 'default' => '1', 'key' => 'index', 'comment' => '公開かどうか'),
),
'frames_languages' => array(
'frame_id' => array('type' => 'integer', 'null' => false, 'default' => null, 'unsigned' => false, 'comment' => 'フレームID'),
'is_translation' => array('type' => 'boolean', 'null' => false, 'default' => '0', 'key' => 'index', 'comment' => '翻訳したかどうか'),
),
),
'create_field' => array(
'frame_public_languages' => array(
'indexes' => array(
'language_id' => array(),
),
),
'frames_languages' => array(
'indexes' => array(
'language_id' => array(),
),
),
),
'drop_field' => array(
'frame_public_languages' => array('indexes' => array('language_id')),
'frames_languages' => array('indexes' => array('language_id')),
),
),
);
/**
* Before migration callback
*
* @param string $direction Direction of migration process (up or down)
* @return bool Should process continue
*/
public function before($direction) {
return true;
}
/**
* After migration callback
*
* @param string $direction Direction of migration process (up or down)
* @return bool Should process continue
*/
public function after($direction) {
return true;
}
}