Pengertian MySQL
MySQL adalah sebuah database management system (manajemen basis data) menggunakan perintah dasar SQL (Structured Query Language) yang cukup terkenal. Database management system (DBMS) MySQL multi pengguna dan multi alur ini sudah dipakai lebih dari 6 juta pengguna di seluruh dunia.
MySQL adalah DBMS yang open source dengan dua bentuk lisensi, yaitu Free Software (perangkat lunak bebas) dan Shareware (perangkat lunak berpemilik yang penggunaannya terbatas). Jadi MySQL adalah database server yang gratis dengan lisensi GNU General Public License (GPL) sehingga dapat Anda pakai untuk keperluan pribadi atau komersil tanpa harus membayar lisensi yang ada.
Seperti yang sudah disinggung di atas, MySQL masuk ke dalam jenis RDBMS (Relational Database Management System). Maka dari itu, istilah semacam baris, kolom, tabel, dipakai pada MySQL. Contohnya di dalam MySQL sebuah database terdapat satu atau beberapa tabel.
SQL sendiri merupakan suatu bahasa yang dipakai di dalam pengambilan data pada relational database atau database yang terstruktur. Jadi MySQL adalah database management system yang menggunakan bahasa SQL sebagai bahasa penghubung antara perangkat lunak aplikasi dengan database server.
Kelebihan dan Kekurangan MySQL
Salah satu kekurangan MySQL adalah performanya turun di saat beberapa database manajemen sistem mampu bekerja baik pada pengelolaan database yang besar. Adapun kelebihan dan kekurangan MySQL lain, di antaranya:
1. Kurang Cocok untuk Aplikasi Game dan Mobile
Anda yang ingin mengembangkan aplikasi game atau perangkat mobile ada baiknya jika mempertimbangkan lagi jika ingin menggunakan MySQL. Kebanyakan pengembang game maupun aplikasi mobile tidak menggunakannya karena memang database manajemen sistem ini masih kurang bagus dipakai untuk sistem aplikasi tersebut.
2. Sulit Mengelola Database yang Besar
Jika Anda ingin mengembangkan aplikasi atau sistem di perusahaan dengan database yang cukup besar, ada baiknya jika menggunakan database manajemen sistem selain MySQL. MySQL dikembangkan supaya ramah dengan perangkat yang mempunyai spesifikasi rendah, itulah mengapa MySQL tidak memiliki fitur yang lengkap seperti aplikasi lainnya.
3. Technical Support yang Kurang Bagus
Sifatnya yang open source terkadang membuat aplikasi tidak menyediakan technical support yang memadai. Technical support MySQL diklaim kurang bagus. Hal ini membuat pengguna kesulitan. Apalagi jika pengguna mengalami masalah yang berhubungan dengan pengoperasian perangkat lunak tersebut dan membutuhkan bantuan technical support.
MySQL mempunyai beberapa kelebihan yang bisa Anda manfaatkan untuk mengembangkan perangkat lunak yang andal seperti:
1. Mendukung Integrasi Dengan Bahasa Pemrograman Lain.
Website atau perangkat lunak terkadang dikembangkan dengan menggunakan berbagai macam bahasa pemrograman, jadi Anda tidak perlu khawatir jika menggunakan MySQL. Maka dari itu, MySQL bisa membantu Anda untuk mengembangkan perangkat lunak yang lebih efektif dan tentu saja lebih mudah dengan integrasi antara bahasa pemrograman.
2. Tidak Membutuhkan RAM Besar.
MySQL dapat dipasang pada server dengan spesifikasi kecil. Jadi tidak perlu khawatir jika Anda hanya mempunyai server dengan kapasitas 1 GB karena Anda masih bisa menggunakan MySQL sebagai database Anda.
3. Mendukung Multi User.
MySQL dapat dipakai oleh beberapa user dalam waktu bersamaan tanpa membuatnya crash atau berhenti bekerja. Ini dapat Anda manfaatkan ketika mengerjakan proyek yang sifatnya tim sehingga seluruh tim dapat bekerja dalam waktu bersamaan tanpa harus menunggu user lain selesai.
4. Bersifat Open Source
MySQL adalah sistem manajemen database gratis. Meskipun gratis, bukan berarti database ini mempunyai kinerja buruk. Apalagi lisensi gratis yang dipakai adalah GPL di bawah pengelolaan Oracle sehingga kualitasnya termasuk baik. Selain itu, Anda juga tidak perlu khawatir jika terjadi masalah karena banyak komunitas dan dokumentasi yang membahas soal MySQL.
5. Struktur Tabel yang Fleksibel.
MySQL mempunyai struktur tabel yang mudah dipakai dan fleksibel. Contohnya saat MySQL memproses ALTER TABLE dan lain sebagainya. Jika dibandingkan dengan database lain seperti Oracle dan PostgreSQL, MySQL tergolong lebih mudah.
6. Tipe Data yang Bervariasi.
Kelebihan lain dari MySQL adalah mendukung berbagai macam data yang bisa Anda gunakan di MySQL. Contohnya float, integer, date, char, text, timestamp, double, dan lain sebagainya. Jadi manajemen database sistem ini sangat membantu Anda untuk mengembangkan perangkat lunak yang berguna untuk pengelolaan database di server.
7. Keamanan yang Terjamin.
Open source bukan berarti MySQL menyediakan keamanan yang buruk. Malah sebaliknya, MySQL mempunyai fitur keamanan yang cukup apik. Ada beberapa lapisan keamanan yang diterapkan oleh MySQL, seperti level nama host, dan subnetmask. Selain itu MySQL juga dapat mengatur hak akses user dengan enkripsi password tingkat tinggi.
Mengenal SQL
SQL merupakan bahasa pemrograman yang perlu Anda pahami karena dapat merelasikan antara beberapa tabel dengan database maupun antar database. Ada tiga bentuk SQL yang perlu Anda ketahui, yaitu Data Definition Language (DDL), Data Manipulation Language(DML), dan Data Control Language (DCL).
CREATE | Dipakai untuk membuat tabel dan database. |
DROP | Dipakai untuk menghapus database dan tabel. |
ALTER | Dipakai untuk mengubah struktur tabel yang sudah ada. Alter dapat mengganti field menggunakan perintah “Change”, menambahkan field menggunakan perintah “Add”, atau menghapus field menggunakan perintah “drop”, dan mengubah namanya menggunakan perintah “Rename”. |
Data Definition Language (DDL)
DDL berguna pada saat Anda ingin mendefinisikan data di dalam database. Terdapat beberapa query yang dikelompokkan ke dalam DDL, yaitu:
Argumen DDL di atas perlu Anda pahami karena merupakan dasar penggunaan SQL di bagian awal pembuatan database. Contohnya saja jika belum menjalankan perintah “CREATE”, Anda belum bisa melanjutkan penggunaan argumen yang lainnya.
Data Manipulation Language (DML)
DML dapat Anda pakai setelah menjalankan perintah DDL. DML berfungsi untuk memanipulasi, mengubah, atau mengganti isi dari database (tabel) yang sudah ada.
Terdapat beberapa perintah DML yang perlu Anda ketahui, yaitu:
INSERT | Dipakai untuk memasukkan data ke dalam tabel pada database. |
UPDATE | Dipakai untuk mengubah data yang ada di dalam tabel pada database. |
DELETE | Dipakai untuk menghapus data di dalam tabel pada database. |
Data Control Language (DCL)
Jika Anda sudah mempunyai user dan ingin mengatur hak akses masing-masing user, Anda sebaiknya memahami berbagai macam jenis DCL dan cara penggunaannya. DCL berguna untuk memberikan hak akses database, mendefinisikan space, mengalokasikan space, dan melakukan audit penggunaan database.
Terdapat beberapa perintah DCL yang perlu Anda ketahui, yaitu:
GRANT | Dipakai untuk memberikan izin kepada user untuk mengakses database. |
REVOKE | Dipakai untuk membatalkan izin user untuk mengakses database. |
COMMIT | Dipakai untuk menetapkan penyimpanan pada database. |
ROOLBACK | Dipakai untuk membatalkan penyimpanan pada database. |
Cara Menginstall MySQL di Windows dan Linux
MySQL server mendukung berbagai macam sistem operasi (cross-platform), khususnya Linux dan Windows. Proses instalasinya pun sangat mudah. Jika menggunakan Windows, Anda bisa menginstall XAMPP untuk menjalankan MySQL server yang di dalamnya sudah terdapat juga modul untuk menjalankan Apache, PHP, FileZilla, dan Tomcat.
Sedangkan di Linux, Anda dapat menginstall MySQL secara terpisah atau menginstall LAMP (Linux, Apache, MySQL, PHP) yang sudah ada modul Apache dan PHP juga. Selain itu, XAMPP juga sudah tersedia di Linux. Jadi Anda bisa menyesuaikan proses instalasi sesuai dengan yang Anda nyaman dan suka.
Cara Install MySQL Server di Windows
Proses instalasi MySQL server menggunakan XAMPP :
Langkah 1. Unduh file instalasi XAMPP
Anda cukup mengunduh file instalasi XAMPP melalui halaman website apachefriends.org.
Langkah 2. Install XAMPP
Setelah selesai proses unduh, silakan eksekusi file instalasi XAMPP untuk menjalankan proses instalasi. Kemudian ikuti instruksi yang ada.
Langkah 3. Aktifkan MySQL server menggunakan GUI XAMPP
Saat Anda selesai menjalankan proses instalasi akan muncul panel kontrol XAMPP. Klik “Start” pada modul Apache dan MySQL. Sampai di sini MySQL server sudah dapat berjalan dan sudah dapat dipakai untuk menjalankan perintah SQL.
Cara Install MySQL Server di Linux
Pada panduan cara install MySQL Server di Linux ini akan menggunakan Terminal sebagai contohnya. Anda bisa menggunakan cara ini atau jika ingin lebih mudah bisa langsung mengunduh file instalasi XAMPP dan menginstallnya seperti contoh Windows di atas.
Langkah 1. Install Server Web Apache
Sebelum Anda menjalankan proses instalasi, ada baiknya untuk memperbarui repositorinya terlebih dahulu. Untuk memperbarui repositori pada Linux caranya cukup mudah, Anda tinggal membuka Terminal kemudian mengetikkan baris komentar berikut:
$ sudo apt get-update |
Kemudian jalankan perintah berikut untuk menginstall Apache.
$ sudo apt get-install apache2 |
Langkah 2. Mengecek Proses Instalasi Apache
Jika proses instalasi Apache sudah selesai dan berhasil dijalankan, Anda bisa mengeceknya dengan mengakses web browser kemudian menuliskan alamat IP server atau alamat domain.
http://<alamat_ip_address_server> |
Langkah 3. Instalasi MySQL
Proses instalasi MySQL server di Linux cukup menggunakan satu perintah saja.
$ sudo apt-get install mysql-server |
Proses instalasi ini akan meminta Anda untuk memasukkan username dan password untuk akses ke dalam MySQL server.
Langkah 4. Pengecekan Instalasi MySQL
Anda dapat memastikan apakah proses instalasi MySQL sudah berjalan baik atau belum dengan mengetikkan perintah di bawah ini.
$ sudo systemctl status mysql |
Perintah di atas untuk mengecek apakah MySQL sudah berjalan atau belum. Jika belum, Terminal akan menampilkan status ‘Error’ atau ‘Failed’.
Fungsi-fungsi di MySQL Server
Jika MySQL sudah dapat berjalan dengan baik di server atau perangkat, ada beberapa fungsi yang bisa Anda jalankan menggunakan teks perintah (command prompt).
Untuk masuk ke dalam MySQL server buka ‘CMD’ di Windows dan ‘Terminal’ di Linux.
Login dan Logout MySQL Server
Pengertian MySQL adalah database manajemen server yang cukup aman sehingga mempunyai aturan hak akses yang ketat. Jadi ketika ingin mengakses MySQL, Anda harus menggunakan password yang sudah diatur sebelumnya.
Jika sebelumnya belum mengatur user untuk masuk ke dalam MySQL, Anda dapat menggunakan user root dengan mengetikkan perintah berikut.
$ mysql -u root -p |
Opsi ‘-u’ merupakan tanda jika ingin login menggunakan user dengan menggunakan password yang dinyatakan dengan opsi ‘-p’.
Jika ingin keluar, Anda hanya perlu mengetikkan perintah “quit” atau “\q”.
Opsi di MySQL Server
MySQL server menyediakan beberapa bantuan yang bisa Anda akses untuk mengubah dan mendokumentasikan server, yaitu dengan mengetikkan perintah “\h” atau “\?” ke dalam koneksi MySQL yang sedang aktif.
Perhatian! Semua koneksi harus diakhiri tanda titik koma (;). Tanda ini sebagai petunjuk bahwa perintah atau query yang dimasukkan sudah selesai dan siap dieksekusi.
Bantuan | \h atau \? | Dipakai untuk menampilkan opsi bantuan yang tersedia di dalam MySQL server. |
Clear | \c | Dipakai untuk menghapus atau membatalkan semua perintah yang berjalan pada satu perintah. |
Connect | \r | Dipakai untuk me-refresh koneksi ke database yang ada di dalam Server Host. |
Ego | \G | Dipakai untuk menampilkan data di dalam database server secara horizontal |
Go | \g | Dipakai untuk mengeksekusi perintah yang sudah dimasukkan. |
Tee | \T | Dipakai untuk mengatur lokasi file untuk perintah yang ingin didokumentasikan. |
Note | \t | Dipakai untuk mengakhiri perintah \T yang berguna untuk mendokumentasikan semua perintah yang sudah dijalankan. |
\p | Dipakai untuk menampilkan seluruh perintah yang sudah dijalankan ke layar. | |
Prompt | \R | Dipakai untuk mengubah ‘prompt’ sesuai dengan keinginan. |
Source | \. | Dipakai untuk mengeksekusi perintah dari luar yang berbentuk file .sql |
Use | \u | Dipakai untuk masuk ke dalam database (mirip dengan perintah “cd” di dalam bash script) |
Perintah Administrasi di MySQL Server
Pengertian MySQL server lainnya yaitu sebuah database manajemen sistem yang bersifat client/server. Jadi sangat penting untuk mengatur hak akses setiap user. Pengaturan hak akses ini supaya semua user mempunyai wewenang yang berbeda. Hak akses juga dapat mengatur user supaya hanya dapat mengakses database tertentu saja.
Pengaturan hak akses di MySQL tentu akan sangat berguna apalagi karena perangkat lunak ini berjalan di jaringan publik yang kemungkinan semua user bisa mengaksesnya melalui internet.
Sebelum mengatur hak akses, Anda harus membuat terlebih dahulu user MySQL selain ‘root’.
Membuat User Baru
Anda dapat menggunakan perintah SQL bernama “INSERT” untuk membuat user baru ke dalam database di MySQL server. Adapun sintaks yang dapat Anda gunakan contohnya:
INSERT INTO user(host, user, password) VALUES(‘%’,’nama_user’,’password’); |
Perintah di atas akan menambahkan user ke dalam tabel ‘user’.
Selain perintah di atas, Anda juga bisa memanfaatkan perintah “GRANT” untuk membuat user dan database. Langkah-langkahnya sebagai berikut.
Langkah 1. Masuk ke Dalam MySQL Server Menggunakan User ‘Root’.
Masuk ke dalam database MySQL dengan menggunakan perintah berikut ini.
$ mysql -u root –p |
Kemudian masukkan password untuk user ‘root’ untuk masuk ke dalam MySQL server.
Langkah 2. Membuat User Untuk Database.
Anda dapat menggunakan contoh perintah berikut ini untuk membuat user untuk database.
Kemudian masukkan password untuk user ‘root’ untuk masuk ke dalam MySQL server.
GRANT ALL PRIVILEGES ON *.* TO ‘username’@’localhost’ IDENTIFIED BY ‘password’; |
Perintah di atas akan membuat user dengan hak akses secara menyeluruh seperti ‘root’. Namun Anda juga dapat menyesuaikan batasan hak ases dari masing-masing user yang dibuat dengan menggunakan perintah “SELECT” seperti perintah berikut.
GRANT SELECT ON *.* TO ‘username’@’localhost’; |
Contoh dari penggunaan GRANT dan SELECT seperti beberapa perintah di bawah ini.
CREATE USER ‘yasin’@’localhost’ IDENTIFIED BY ‘password’; |
GRANT ALL ON db1.* TO ‘yasin’@’localhost’; |
GRANT SELECT ON db2.karyawan TO ‘yasin’@’localhost’; |
GRANT USAGE ON *.* TO ‘yasin’@’localhost’ WITH MAX_QUERIES_PER_HOUR 90; |
Setelah selesai menambahkan user, akhiri session menggunakan perintah “quit” atau “\q”.
Langkah 3. Membuat Database Menggunakan User Baru.
Masuk ke kembali ke dalam database server menggunakan user yang sudah dibuat.
$ mysql -u username –p |
Kemudian buat database menggunakan perintah “CREATE”.
CREATE DATABASE nama_database; |
Langkah 4. Memasukkan Tabel ke Dalam Database.
Jika database sudah dibuat, Anda harus masuk ke dalam database tersebut untuk membuat tabel menggunakan perintah “USE”.
USE karyawan; |
Setelah masuk, gunakan perintah “CREATE TABLE” untuk membuat tabel sesuai dengan kebutuhan data yang ingin dimasukkan, contohnya di bawah ini.
CREATE TABLE contoh( id smallint unsigned not null auto_increment, name varchar(20) not null, constraint pk_example primary key (id) ); |
INSERT INTO contoh( id, name ) VALUES ( null, ‘Sample data’ ); |
Memberikan Hak Akses ke User
Jika sudah membuat user tetapi lupa untuk membuat hak akses, Anda masih dapat mengubahnya dan memberikan akses menggunakan perintah “GRANT”. Contoh penggunaan sintaksnya seperti berikut.
Langkah 1. Melihat Seluruh User yang Sudah Ada.
Anda dapat melihat seluruh user yang ada di dalam MySQL server menggunakan perintah “SELECT’ seperti baris perintah berikut ini.
SELECT user, host from mysql.user; |
Langkah 2. Melihat Hak Akses User.
Jika sudah menemukan user yang dimaksud, Anda bisa mengecek hak akses yang saat ini berlaku untuk user tersebut menggunakan perintah “GRANT”.
show grants for ‘user’@’host’; |
Langkah 3. Membatalkan Hak Akses User.
Sebelum mengatur ulang hak akses baru untuk user yang sudah ada, terlebih dahulu Anda harus membatalkan hak akses yang berlaku saat ini menggunakan perintah “REVOKE”.
revoke all privileges on *.* from ‘user’@’host’; |
Langkah 4. Memberikan Hak Akses.
Berikan kembali hak akses ke user yang sudah dihapuskan hak aksesnya menggunakan perintah “GRANT” dengan beberapa opsi yang berlaku seperti ‘SELECT’, ‘INSERT’, ‘UPDATE’, atau ‘DELETE’.
GRANT SELECT, INSERT, UPDATE, DELETE ON `db`.* TO ‘user’@’host’; |
Langkah 5. Melakukan flush.
Setelah selesai jangan lupa untuk melakukan flush. Perintah ini berguna untuk memperbarui dan menerapkan aturan baru yang berlaku.
flush privileges; |
Kesimpulan
MySQL adalah sebuah sistem manajemen database yang berguna untuk mengelola database di dalam website. Sistem manajemen database dengan mysql mempunyai banyak fitur. Selain itu, proses instalasi sampai dengan penggunaannya sangat mudah sehingga bagi pengguna yang masing awam pun mungkin akan cepat untuk memahaminya.
Kebutuhan akan digital IT sangat dibutuhkan dalam kegiatan sehari-hari, Bead IT Consultant merupakan pilihan tepat sebagai partner anda,kunjungi website kami dengan klik link ini : www.beadgrup.com