|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521 |
- <?php
-
-
- namespace yii\db;
-
- use yii\base\Component;
- use yii\di\Instance;
-
-
- class Migration extends Component implements MigrationInterface
- {
- use SchemaBuilderTrait;
-
-
-
- public $db = 'db';
-
-
-
-
- public function init()
- {
- parent::init();
- $this->db = Instance::ensure($this->db, Connection::className());
- $this->db->getSchema()->refresh();
- $this->db->enableSlaves = false;
- }
-
-
-
- protected function getDb()
- {
- return $this->db;
- }
-
-
-
- public function up()
- {
- $transaction = $this->db->beginTransaction();
- try {
- if ($this->safeUp() === false) {
- $transaction->rollBack();
-
- return false;
- }
- $transaction->commit();
- } catch (\Exception $e) {
- echo 'Exception: ' . $e->getMessage() . ' (' . $e->getFile() . ':' . $e->getLine() . ")\n";
- echo $e->getTraceAsString() . "\n";
- $transaction->rollBack();
-
- return false;
- }
-
- return null;
- }
-
-
-
- public function down()
- {
- $transaction = $this->db->beginTransaction();
- try {
- if ($this->safeDown() === false) {
- $transaction->rollBack();
-
- return false;
- }
- $transaction->commit();
- } catch (\Exception $e) {
- echo 'Exception: ' . $e->getMessage() . ' (' . $e->getFile() . ':' . $e->getLine() . ")\n";
- echo $e->getTraceAsString() . "\n";
- $transaction->rollBack();
-
- return false;
- }
-
- return null;
- }
-
-
-
- public function safeUp()
- {
- }
-
-
-
- public function safeDown()
- {
- }
-
-
-
- public function execute($sql, $params = [])
- {
- echo " > execute SQL: $sql ...";
- $time = microtime(true);
- $this->db->createCommand($sql)->bindValues($params)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function insert($table, $columns)
- {
- echo " > insert into $table ...";
- $time = microtime(true);
- $this->db->createCommand()->insert($table, $columns)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function batchInsert($table, $columns, $rows)
- {
- echo " > insert into $table ...";
- $time = microtime(true);
- $this->db->createCommand()->batchInsert($table, $columns, $rows)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function update($table, $columns, $condition = '', $params = [])
- {
- echo " > update $table ...";
- $time = microtime(true);
- $this->db->createCommand()->update($table, $columns, $condition, $params)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function delete($table, $condition = '', $params = [])
- {
- echo " > delete from $table ...";
- $time = microtime(true);
- $this->db->createCommand()->delete($table, $condition, $params)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function createTable($table, $columns, $options = null)
- {
- echo " > create table $table ...";
- $time = microtime(true);
- $this->db->createCommand()->createTable($table, $columns, $options)->execute();
- foreach ($columns as $column => $type) {
- if ($type instanceof ColumnSchemaBuilder && $type->comment !== null) {
- $this->db->createCommand()->addCommentOnColumn($table, $column, $type->comment)->execute();
- }
- }
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function renameTable($table, $newName)
- {
- echo " > rename table $table to $newName ...";
- $time = microtime(true);
- $this->db->createCommand()->renameTable($table, $newName)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function dropTable($table)
- {
- echo " > drop table $table ...";
- $time = microtime(true);
- $this->db->createCommand()->dropTable($table)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function truncateTable($table)
- {
- echo " > truncate table $table ...";
- $time = microtime(true);
- $this->db->createCommand()->truncateTable($table)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function addColumn($table, $column, $type)
- {
- echo " > add column $column $type to table $table ...";
- $time = microtime(true);
- $this->db->createCommand()->addColumn($table, $column, $type)->execute();
- if ($type instanceof ColumnSchemaBuilder && $type->comment !== null) {
- $this->db->createCommand()->addCommentOnColumn($table, $column, $type->comment)->execute();
- }
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function dropColumn($table, $column)
- {
- echo " > drop column $column from table $table ...";
- $time = microtime(true);
- $this->db->createCommand()->dropColumn($table, $column)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function renameColumn($table, $name, $newName)
- {
- echo " > rename column $name in table $table to $newName ...";
- $time = microtime(true);
- $this->db->createCommand()->renameColumn($table, $name, $newName)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function alterColumn($table, $column, $type)
- {
- echo " > alter column $column in table $table to $type ...";
- $time = microtime(true);
- $this->db->createCommand()->alterColumn($table, $column, $type)->execute();
- if ($type instanceof ColumnSchemaBuilder && $type->comment !== null) {
- $this->db->createCommand()->addCommentOnColumn($table, $column, $type->comment)->execute();
- }
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function addPrimaryKey($name, $table, $columns)
- {
- echo " > add primary key $name on $table (" . (is_array($columns) ? implode(',', $columns) : $columns) . ') ...';
- $time = microtime(true);
- $this->db->createCommand()->addPrimaryKey($name, $table, $columns)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function dropPrimaryKey($name, $table)
- {
- echo " > drop primary key $name ...";
- $time = microtime(true);
- $this->db->createCommand()->dropPrimaryKey($name, $table)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function addForeignKey($name, $table, $columns, $refTable, $refColumns, $delete = null, $update = null)
- {
- echo " > add foreign key $name: $table (" . implode(',', (array) $columns) . ") references $refTable (" . implode(',', (array) $refColumns) . ') ...';
- $time = microtime(true);
- $this->db->createCommand()->addForeignKey($name, $table, $columns, $refTable, $refColumns, $delete, $update)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function dropForeignKey($name, $table)
- {
- echo " > drop foreign key $name from table $table ...";
- $time = microtime(true);
- $this->db->createCommand()->dropForeignKey($name, $table)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function createIndex($name, $table, $columns, $unique = false)
- {
- echo ' > create' . ($unique ? ' unique' : '') . " index $name on $table (" . implode(',', (array) $columns) . ') ...';
- $time = microtime(true);
- $this->db->createCommand()->createIndex($name, $table, $columns, $unique)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function dropIndex($name, $table)
- {
- echo " > drop index $name on $table ...";
- $time = microtime(true);
- $this->db->createCommand()->dropIndex($name, $table)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function addCommentOnColumn($table, $column, $comment)
- {
- echo " > add comment on column $column ...";
- $time = microtime(true);
- $this->db->createCommand()->addCommentOnColumn($table, $column, $comment)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function addCommentOnTable($table, $comment)
- {
- echo " > add comment on table $table ...";
- $time = microtime(true);
- $this->db->createCommand()->addCommentOnTable($table, $comment)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function dropCommentFromColumn($table, $column)
- {
- echo " > drop comment from column $column ...";
- $time = microtime(true);
- $this->db->createCommand()->dropCommentFromColumn($table, $column)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
-
-
-
- public function dropCommentFromTable($table)
- {
- echo " > drop comment from table $table ...";
- $time = microtime(true);
- $this->db->createCommand()->dropCommentFromTable($table)->execute();
- echo ' done (time: ' . sprintf('%.3f', microtime(true) - $time) . "s)\n";
- }
- }
|