MySQLi - Perintah ALTER
MySQLi ALTER Perintah ini sangat berguna ketika Anda ingin mengubah nama tabel Anda, bidang tabel apa pun atau jika Anda ingin menambah atau menghapus kolom yang sudah ada dalam tabel.
Mari kita mulai dengan membuat tabel bernama tutorials_alter.
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> create table tutorials_alter
-> (
-> i INT,
-> c CHAR(1)
-> );
Query OK, 0 rows affected (0.27 sec)
mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| i | int(11) | YES | | NULL | |
| c | char(1) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.02 sec)
Menjatuhkan, Menambah atau Memosisikan Ulang Kolom
Misalkan Anda ingin menjatuhkan kolom yang sudah ada i dari tabel MySQLi atas maka Anda akan menggunakan DROP klausul bersama dengan ALTER perintah sebagai berikut -
mysql> ALTER TABLE tutorials_alter DROP i;
SEBUAH DROP tidak akan berfungsi jika kolom adalah satu-satunya yang tersisa di tabel.
Untuk menambahkan kolom, gunakan ADD dan tentukan definisi kolom. Pernyataan berikut memulihkani kolom ke tutorials_alter -
mysql> ALTER TABLE tutorials_alter ADD i INT;
Setelah mengeluarkan pernyataan ini, testalter akan berisi dua kolom yang sama seperti saat Anda pertama kali membuat tabel, tetapi tidak akan memiliki struktur yang sama. Itu karena kolom baru ditambahkan ke akhir tabel secara default. Jadi meskipun begitui awalnya adalah kolom pertama di mytbl, sekarang menjadi yang terakhir.
mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| c | char(1) | YES | | NULL | |
| i | int(11) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.01 sec)
Untuk menunjukkan bahwa Anda menginginkan kolom pada posisi tertentu dalam tabel, gunakan FIRST untuk menjadikannya kolom pertama atau SETELAH col_name untuk menunjukkan bahwa kolom baru harus ditempatkan setelah col_name. Coba pernyataan ALTER TABLE berikut, menggunakan TAMPILKAN KOLOM setelah masing-masing untuk melihat apa efek masing-masing -
ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT FIRST;
ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT AFTER c;
Penentu FIRST dan AFTER hanya bekerja dengan klausa ADD. Ini berarti bahwa jika Anda ingin memposisikan ulang kolom yang sudah ada di dalam tabel, Anda harus DROP terlebih dahulu lalu TAMBAH di posisi baru.
Mengubah Definisi atau Nama Kolom
Untuk mengubah definisi kolom, gunakan MODIFY atau CHANGEklausa bersama dengan perintah ALTER. Misalnya untuk mengganti kolomc dari CHAR (1) ke CHAR (10), lakukan ini -
mysql> ALTER TABLE tutorials_alter MODIFY c CHAR(10);
Dengan CHANGE, sintaksnya sedikit berbeda. Setelah kata kunci CHANGE, Anda memberi nama kolom yang ingin Anda ubah, lalu tentukan definisi baru, yang menyertakan nama baru. Coba contoh berikut:
mysql> ALTER TABLE tutorials_alter CHANGE i j BIGINT;
Jika Anda sekarang menggunakan CHANGE untuk mengubah j dari BIGINT kembali ke INT tanpa mengubah nama kolom, pernyataannya akan seperti yang diharapkan -
mysql> ALTER TABLE tutorials_alter CHANGE j j INT;
Pengaruh ALTER TABLE pada Atribut Nilai Null dan Default -
Saat Anda MENGUBAH atau MENGUBAH kolom, Anda juga dapat menentukan apakah kolom tersebut dapat berisi nilai NULL dan berapa nilai default-nya. Faktanya, jika Anda tidak melakukan ini, MySQLi secara otomatis memberikan nilai untuk atribut ini.
Berikut adalah contoh di mana kolom NOT NULL akan memiliki nilai 100 secara default.
mysql> ALTER TABLE tutorials_alter
-> MODIFY j BIGINT NOT NULL DEFAULT 100;
Jika Anda tidak menggunakan perintah di atas, maka MySQLi akan mengisi nilai NULL di semua kolom.
Mengubah Nilai Default Kolom
Anda dapat mengubah nilai default untuk setiap kolom menggunakan perintah ALTER. Coba contoh berikut.
mysql> ALTER TABLE tutorials_alter ALTER j SET DEFAULT 1000;
mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| c | char(10) | YES | | NULL | |
| j | bigint(20) | NO | | 1000 | |
+-------+------------+------+-----+---------+-------+
2 rows in set (0.02 sec)
Anda dapat menghapus batasan default dari kolom mana pun dengan menggunakan klausa DROP bersama dengan perintah ALTER.
mysql> ALTER TABLE tutorials_alter ALTER j DROP DEFAULT;
mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| c | char(10) | YES | | NULL | |
| j | bigint(20) | NO | | NULL | |
+-------+------------+------+-----+---------+-------+
2 rows in set (0.02 sec)
Mengubah Jenis Tabel
Anda dapat menggunakan tipe tabel dengan menggunakan TYPE klausa bersama dengan perintah ALTER.
Untuk mengetahui tipe tabel saat ini, gunakan pernyataan SHOW TABLE STATUS.
mysql> SHOW TABLE STATUS LIKE 'tutorials_alter'\G
*************************** 1. row ***************************
Name: tutorials_alter
Engine: InnoDB
Version: 10
Row_format: Compact
Rows: 0
Avg_row_length: 0
Data_length: 16384
Max_data_length: 0
Index_length: 0
Data_free: 0
Auto_increment: NULL
Create_time: 2017-02-17 11:30:29
Update_time: NULL
Check_time: NULL
Collation: latin1_swedish_ci
Checksum: NULL
Create_options:
Comment:
1 row in set (0.00 sec)
Mengganti Nama Tabel
Untuk mengganti nama tabel, gunakan RENAMEopsi dari pernyataan ALTER TABLE. Coba contoh berikut untuk mengganti nama tutorials_alter menjadi tutorials_bks.
mysql> ALTER TABLE tutorials_alter RENAME TO tutorials_bks;
Anda dapat menggunakan perintah ALTER untuk membuat dan meletakkan INDEX pada file MySQL. Kita akan melihat fitur ini di bab selanjutnya.