MySQL - Administrasi

Menjalankan dan Mematikan Server MySQL

Pertama, periksa apakah server MySQL Anda berjalan atau tidak. Anda dapat menggunakan perintah berikut untuk memeriksanya -

ps -ef | grep mysqld

Jika MySql Anda aktif, Anda akan melihat mysqldproses yang tercantum dalam hasil Anda. Jika server tidak berjalan, Anda dapat memulainya dengan menggunakan perintah berikut -

root@host# cd /usr/bin
./safe_mysqld &

Sekarang, jika Anda ingin mematikan server MySQL yang sudah berjalan, Anda dapat melakukannya dengan menggunakan perintah berikut -

root@host# cd /usr/bin
./mysqladmin -u root -p shutdown
Enter password: ******

Menyiapkan Akun Pengguna MySQL

Untuk menambahkan pengguna baru ke MySQL, Anda hanya perlu menambahkan entri baru ke user tabel dalam database mysql.

Program berikut adalah contoh penambahan pengguna baru guest dengan hak istimewa SELECT, INSERT dan UPDATE dengan password guest123; kueri SQL adalah -

root@host# mysql -u root -p
Enter password:*******
mysql> use mysql;
Database changed

mysql> INSERT INTO user 
   (host, user, password, 
   select_priv, insert_priv, update_priv) 
   VALUES ('localhost', 'guest', 
   PASSWORD('guest123'), 'Y', 'Y', 'Y');
Query OK, 1 row affected (0.20 sec)

mysql> FLUSH PRIVILEGES;
Query OK, 1 row affected (0.01 sec)

mysql> SELECT host, user, password FROM user WHERE user = 'guest';
+-----------+---------+------------------+
|    host   |   user  |     password     |    
+-----------+---------+------------------+
| localhost |  guest  | 6f8c114b58f2ce9e |
+-----------+---------+------------------+
1 row in set (0.00 sec)

Saat menambahkan pengguna baru, ingatlah untuk mengenkripsi kata sandi baru menggunakan fungsi PASSWORD () yang disediakan oleh MySQL. Seperti yang Anda lihat pada contoh di atas, sandi mypass dienkripsi ke 6f8c114b58f2ce9e.

Perhatikan pernyataan FLUSH PRIVILEGES. Ini memberitahu server untuk memuat ulang tabel hibah. Jika Anda tidak menggunakannya, maka Anda tidak akan dapat terhubung ke MySQL menggunakan akun pengguna baru setidaknya sampai server di-boot ulang.

Anda juga dapat menentukan hak istimewa lain untuk pengguna baru dengan menyetel nilai kolom berikut di tabel pengguna ke 'Y' saat menjalankan kueri INSERT atau Anda dapat memperbaruinya nanti menggunakan kueri UPDATE.

  • Select_priv
  • Insert_priv
  • Update_priv
  • Delete_priv
  • Create_priv
  • Drop_priv
  • Reload_priv
  • Shutdown_priv
  • Process_priv
  • File_priv
  • Grant_priv
  • References_priv
  • Index_priv
  • Alter_priv

Cara lain untuk menambahkan akun pengguna adalah dengan menggunakan perintah GRANT SQL. Contoh berikut akan menambahkan penggunazara dengan kata sandi zara123 untuk database tertentu, yang dinamai sebagai TUTORIALS.

root@host# mysql -u root -p password;
Enter password:*******
mysql> use mysql;
Database changed

mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP
   -> ON TUTORIALS.*
   -> TO 'zara'@'localhost'
   -> IDENTIFIED BY 'zara123';

Ini juga akan membuat entri di tabel database MySQL yang disebut sebagai user.

NOTE - MySQL tidak menghentikan perintah sampai Anda memberikan titik koma (;) di akhir perintah SQL.

Konfigurasi File /etc/my.cnf

Dalam kebanyakan kasus, Anda tidak boleh menyentuh file ini. Secara default, ini akan memiliki entri berikut -

[mysqld]
datadir = /var/lib/mysql
socket = /var/lib/mysql/mysql.sock

[mysql.server]
user = mysql
basedir = /var/lib

[safe_mysqld]
err-log = /var/log/mysqld.log
pid-file = /var/run/mysqld/mysqld.pid

Di sini, Anda dapat menentukan direktori lain untuk log kesalahan, jika tidak, Anda tidak boleh mengubah entri apa pun dalam tabel ini.

Perintah MySQL Administratif

Berikut adalah daftar perintah penting MySQL, yang akan Anda gunakan dari waktu ke waktu untuk bekerja dengan database MySQL -

  • USE Databasename - Ini akan digunakan untuk memilih database di area kerja MySQL.

  • SHOW DATABASES - Mencantumkan database yang dapat diakses oleh DBMS MySQL.

  • SHOW TABLES - Menampilkan tabel dalam database setelah database dipilih dengan perintah penggunaan.

  • SHOW COLUMNS FROM tablename: Menunjukkan atribut, jenis atribut, informasi kunci, apakah NULL diizinkan, default, dan informasi lain untuk tabel.

  • SHOW INDEX FROM tablename - Menyajikan detail semua indeks di atas tabel, termasuk KUNCI UTAMA.

  • SHOW TABLE STATUS LIKE tablename\G - Laporan detail kinerja dan statistik MySQL DBMS.

Pada bab selanjutnya, kita akan membahas tentang bagaimana PHP Syntax digunakan di MySQL.