Yii - Migrasi Database
Selama pengembangan aplikasi berbasis database, struktur database berkembang dengan kode sumber. Yii menyediakandatabase migration fitur yang memungkinkan Anda melacak perubahan database.
Yii menyediakan alat baris perintah migrasi berikut -
- Buat migrasi baru
- Kembalikan migrasi
- Terapkan migrasi
- Terapkan kembali migrasi
- Tampilkan status dan riwayat migrasi
Membuat Migrasi
Mari kita buat migrasi database baru.
Step 1 - Di dalam root proyek dari template aplikasi dasar buka jendela konsol dan jalankan.
./yii migrate/create add_news_table
Perintah di atas akan membuat file migrasi baru (m160113_102634_add_news_table.php dalam kasus ini) di migrations map.
File tersebut berisi kode berikut -
<?php
use yii\db\Schema;
use yii\db\Migration;
class m160113_102634_add_news_table extends Migration {
public function up() {
}
public function down() {
echo "m160113_102634_add_news_table cannot be reverted.\n";
return false;
}
/*
// Use safeUp/safeDown to run migration code within a transaction
public function safeUp() {
}
public function safeDown() {
}
*/
}
?>
Setiap migrasi DB adalah kelas PHP yang memperluas yii\db\Migrationkelas. Nama kelas dibuat dalam format berikut -
m<YYMMDD_HHMMSS>_<Name>
dimana <YYMMDD_HMMSS> adalah tanggal waktu UTC saat perintah migrasi dijalankan dan <Name> adalah argumen yang Anda berikan di perintah konsol.
Metode up () dipanggil saat Anda mengupgrade database, sedangkan metode down () dipanggil saat Anda menurunkannya.
Step 2 - Untuk menambahkan tabel baru ke database, ubah file migrasi dengan cara ini.
<?php
use yii\db\Schema;
use yii\db\Migration;
class m160113_102634_add_news_table extends Migration {
public function up() {
$this->createTable("news", [ "id" => Schema::TYPE_PK, "title" => Schema::TYPE_STRING, "content" => Schema::TYPE_TEXT, ]); } public function down() { $this->dropTable('news');
}
/*
// Use safeUp/safeDown to run migration code within a transaction
public function safeUp() {
}
public function safeDown() {
}
*/
}
?>
Pada kode di atas kami membuat tabel baru bernama berita di up() metode dan menjatuhkan tabel ini di down() metode.
Itu newstabel terdiri dari tiga bidang: id, judul, dan konten. Saat membuat tabel atau kolom kita harus menggunakan tipe abstrak sehingga migrasi tidak tergantung pada tipe database. Misalnya, dalam kasus MySQL, TYPE_PK akan diubah menjadi int (11) NOT NUL AUTO_INCREMETN PRIMARY KEY.
Step 3 - Untuk mengupgrade database, jalankan perintah ini.
./yii migrate
Perintah di atas akan mencantumkan semua migrasi yang tersedia yang belum diterapkan. Kemudian, jika Anda mengonfirmasi untuk menerapkan migrasi, ini akan menjalankan safeUp () atau up () di semua kelas migrasi baru.
Step 4 - Untuk menerapkan hanya tiga migrasi yang tersedia, Anda dapat menjalankan.
./yii migrate 3
Step 5 - Anda juga dapat menentukan migrasi tertentu tempat basis data harus dimigrasi.
# menggunakan stempel waktu untuk menentukan migrasi
yii migrate/to 160202_195501
# menggunakan string yang dapat diurai oleh strtotime ()
yii migrate/to "2016-01-01 19:55:01"
# menggunakan nama lengkap
yii migrate/to m160202_195501_create_news_table
# menggunakan stempel waktu UNIX
yii migrate/to 1393964718
Step 6 - Untuk mengembalikan metode migrasi (mengeksekusi down () atau safeDown ()), jalankan.
./yii migrate/down
Step 7 - Untuk mengembalikan lima migrasi yang terakhir diterapkan, Anda dapat menjalankan.
./yii migrate/down 5
Step 8 - Untuk mengulang (mengembalikan lalu menerapkan lagi) migrasi, jalankan.
./yii migrate/redo
Untuk mendaftar migrasi yang sudah diterapkan, gunakan perintah ini -
yii migrate/new # menunjukkan 10 migrasi baru pertama
yii migrate/new 3 # menunjukkan 3 migrasi baru pertama
yii migrate/new all # menunjukkan semua migrasi baru
yii migrate/history # menunjukkan 10 migrasi terakhir yang diterapkan
yii migrate/history 20 # menunjukkan 20 migrasi terakhir yang diterapkan
yii migrate/history all # menunjukkan semua migrasi yang diterapkan
Terkadang Anda perlu menambahkan atau menjatuhkan kolom dari tabel tertentu. Kamu dapat memakaiaddColumn() dan dropColumn() metode.
Step 1 - Buat migrasi baru.
./yii migrate/create add_category_to_news
Step 2 - Ubah file migrasi yang baru dibuat dengan cara ini.
<?php
use yii\db\Schema;
use yii\db\Migration;
class m160113_110909_add_category_to_news extends Migration {
public function up() {
$this->addColumn('news', 'category', $this->integer());
}
public function down() {
$this->dropColumn('news', 'category');
}
}
?>
Sekarang, jika Anda lari ./yii migrate, kolom kategori harus ditambahkan ke tabel berita. Sebaliknya, jika Anda lari./yii migrate/down 1, kolom kategori harus dibuang.
Saat melakukan migrasi DB, penting untuk memastikan setiap migrasi berhasil atau gagal. Direkomendasikan untuk menyertakan operasi DB dalam sebuah transaksi. Untuk mengimplementasikan migrasi transaksional, Anda cukup memasukkan kode migrasi disafeUp() dan safeDown()metode. Jika ada operasi dalam metode ini yang gagal, semua operasi sebelumnya akan dibatalkan.
Contoh sebelumnya dalam "cara transaksional" akan -
<?php
use yii\db\Schema;
use yii\db\Migration;
class m160113_110909_add_category_to_news extends Migration {
public function safeUp() {
$this->addColumn('news', 'category', $this->integer()); } public function safeDown() { $this->dropColumn('news', 'category');
}
}
?>
Itu yii\db\Migration kelas menyediakan metode berikut untuk memanipulasi database -
execute() - Menjalankan pernyataan SQL mentah
createTable() - Membuat meja
renameTable() - Ubah nama tabel
insert() - Menyisipkan satu baris
batchInsert() - Menyisipkan beberapa baris
update() - Memperbarui baris
delete() - Menghapus baris
addColumn() - Menambahkan kolom
renameColumn() - Mengganti nama kolom
dropColumn() - Menghapus kolom
alterColumn() - Mengubah kolom
dropTable() - Menghapus meja
truncateTable() - Menghapus semua baris dalam sebuah tabel
createIndex() - Membuat indeks
dropIndex() - Menghapus indeks
addPrimaryKey() - Menambahkan kunci utama
dropPrimaryKey() - Menghapus kunci utama
addForeignKey() - Menambahkan kunci asing
dropForeignKey() - Menghapus kunci asing