Migrasi MySQL ke MySQLi pada PHP – Halo selamat datang kembali di seri tutorial lengkap PHP dari malasngoding.com Kali ini akan kita bahas bagimana migrasi dari MySQL ke MySQLI pada PHP.
Materi ini kami buat mengingat banyak pertanyaan dari pengunjung karena aplikasi yang dikerjakan menggunakan MySQL akan error jika di jalankan di PHP versi 7 yang sudah support akan MySQLI.
Migrasi MySQL ke MySQLi pada PHP
Secara garis besar tidak ada perbedaan antara MySQL dan MySQLi. Hanya saja mysql ini merupakan versi lama yang digunakan dan tidak disarankan lagi untuk mengembangkan aplikasi menggunakan mysql ini dikarenakan ada kemungkinan untuk dihapus kedepannya.
Sedangkan MYSQLi (MySQL Improved Extension) merupakan versi baru dari mysql yang sudah diperbaiki. Mysqli ini dibuat untuk mendukung fitur-fitur terbaru dari mysql. Nama-nama yang digunakan pada mysqli ini juga hampir sama dengan yang digunakan oleh mysql.
Sebagai contoh, misalnya kita membuat koneksi antara database dan php. Jika menggunakan mysql kita menggunakan perintah mysql_connect(). maka jika menggunakan mysqli kita hanya menambahkan i di kata mysql lebih tepatnya mysqli_connect(). Begitu juga dalam proses pemanggilan data dari mysql_query() menjadi mysqli_query().
Kenapa tadi saya bilang mysql ada kemungkinan dihapus kedepannya, hal ini karena jika kita lihat pada php versi 7 – keatas mysql tidak bisa lagi digunakan. Versi php terakhir yang masih bisa menggunakan mysql seingat saya php versi 5.6 ke bawah.
Dengan alasan yang diatas ini sudah sepantasnya kita bermigrasi dari mysql ke mysqli. Nah bagaimana jika project sudah dikerjakan menggunakan mysql dan mau di upgrade ke mysqli ?.
Memang sekarang masih tidak ada masalah jika menggunakan mysql dengan versi php 5 ke bawah. Namun ada baiknya sobat meng-upgrade/migrasi dari mysql ke mysqli. Salah satu kejadian yang saya alami yaitu ketika saya menginstalasi project ke hosting dan error karena saya lupa downgrade versi PHP nya.
Oleh karena itu menurut saya perlu kita bermigrasi dari mysql ke mysqli.
Untuk bermigrasi dari mysql ke mysqli sebenarnya sangatlah mudah, tidak ada perbedaan secara khusus. Berikut akan saya berikan beberapa contoh migrasi dari mysql ke mysqli :
Membuat Koneksi database dengan php
Jika menggunakan mysql untuk membuat database menggunakan mysql_connect maka dengan mysqli kita menggunakan mysqli_connect. Contohnya :
|
<strong>// menggunakan mysql</strong> <?php $koneksi = mysql_connect("localhost","root","","tutorial"); ?> |
|
<strong>menggunakan mysqli</strong> <?php $koneksi = mysqli_connect("localhost","root","","tutorial"); ?> |
Nah dalam potongan kedua kode diatas bisa kita lihat perbedaannya dari menggunakan mysql ke mysqli.
Menampilkan data menggunakan mysql dan mysqli
Contoh lain dari migrasi dari mysql ke mysqli adalah menampilkan data. Jika menggunakan mysql perintahnya mysqli_query(), maka jika menggunakan mysqi maka itu menjadi mysqli_query(). Perhatikan kode berikut :
|
// menggunakan mysql <?php include "koneksi.php"; $data= mysql_query("SELECT * FROM pegawai")or die(mysql_error()); ?> |
jika menggunakan mysql misalnya kita akan memanggil data pegawai yang akan kita simpan dalam variabel data maka $data = mysql_query(“dilanjutkan dengan perintah menampilkan data”). Coba lihat code berikut yang menggunakan mysqli untuk menampilkan data :
|
// Menggunakan mysqli <?php include 'koneksi.php'; $data = mysqli_query($koneksi,"SELECT * FROM pegawai"); ?> |
Dalam potongan kode diatas dapat kita lihat bahwa perbedaan mysql dengan mysqli agak sedikit nampak, dimana ada pada : mysqli_query(), dan penambahan $koneksi sebelum perintah menampilkan data. Variabel $koneksi disini adalah variabel yang menyimpan koneksi database dengan php yang dalam file koneksi.php, dimana sudah kita includekan terlebih dahulu.
Menambahkan data menggunakan mysql dan mysqli
Oke selanjutnya akan kita bahas bagaimana cara bermigrasi dari mysql ke mysqli dalam penambahan data pada php. Perhatikan kode berikut :
|
<?php // menggunakan mysql include 'koneksi.php'; mysql_query("INSERT INTO pegawai VALUES('','Amin','Jaksel','Manager')"); ?> |
|
<?php // menggunakan mysqli include 'koneksi.php'; mysqli_query($koneksi,"INSERT INTO pegawai VALUES('','Amin','Jaksel','Manager')"); ?> |
Oke perbedaannya tetap pada perintah mysqli_query() dan pemakaian variabel $koneksi ada atau tidak. Berikut tabel perubahan dari mysql ke mysqli :
MySQL |
MySQLi |
mysql_query() |
mysqli_query |
mysql_num_rows() |
mysqli_num_rows() |
mysql_fetch_array() |
mysqli_fetch_array() |
mysqli_close() |
mysqli_close() |
mysql_insert_id() |
mysqli_insert_id() |
dan masih banyak lainnya |
dan masih banyak lainny |
Untuk melihat kasus langsung bisa melihat contoh kasus langsung dari proses pembuatan crud yang menggunakan mysql dan mysqli
- Membuat crud menggunakan PHP dan MySQL
- Membuat crud menggunakan PHP dan MySQLi
Kesimpulan yang dapat kita ambil dari judul artikel migrasi mysql ke mysqli pada php adalah:
- Mysqli adalah versi baru dari mysql
- Untuk bermigrasi dari mysql ke mysqli kita hanya perlu mengganti mysql ke mysqli.
misalnya : mysql_num_rows() menjadi mysqli_num_rows().
- Jika dalam mengeksekusi query menggunakan mysqli tambahkan variabel yang menyimpan koneksi php dengan database, misqlnya mysqli_query($koneksi,”–perintah eksekusi database–“).
- Jadi sobat hanya perlu menggantikan mysql ke mysqli dengan cara yang sudah disampaikan diatas. Dan dijamin aplikasi sobat bisa berjalan di php versi 7 ke atas.
Oke, sekian dulu materi Migrasi MySQL ke MySQLI pada PHP kita berjumpa lagi di materi selanjutnya untuk melengkapi seri tutorial lengkap. Kritik dan saran sangat kami harapkan untuk peningkatan kedepannya.