Pembahasan tutorial kali ini merupakan kebalikan dari tutorial sebelumnya. Tutorial ini akan membahas bagaimana membuat script PHP untuk mengenerate data format JSON yang berasal dari database MySQL/MariaDB.

Studi kasus yang akan dipilih, masih sama dengan sebelumnya yaitu menggunakan data kota-kota yang ada di Inggris.

Misalkan kita memiliki sebuah tabel dengan nama ‘zip’ di MySQL/MariaDB sebagai berikut:

Isi tabel data MySQL/MariaDB kota/daerah di Inggris

Dari data di atas, kita akan mengenerate data format JSON dengan struktur setiap record datanya sebagai berikut:

Contoh format struktur JSON dari sebuah record data kota “AGAWAM”

Ide dasar untuk mengenerate data JSON dari MySQL/MariaDB adalah sebagai berikut:

  1. Membaca semua record data dari tabel database melalui sebuah query
  2. Untuk setiap recordnya, dibuat struktur array asosiatif menyesuaikan dengan format JSON yang dikehendaki.
  3. Selanjutnya array asosiatif yang dihasilkan dilakukan encode JSON untuk menghasilkan format JSON
  4. Tampilkan JSON ke web

Dalam hal ini langkah 2, 3, dan 4 dilakukan terus menerus untuk semua record data yang terbaca dari database.

Catatan: Array asosiatif adalah array yang elemennya berbentuk pasangan key dan value. Dengan demikian index dari array asosiatif ini tidak lain adalah key itu sendiri. Misalnya: $x = array(“key1”: value1, “key2”: value2, …)

Implementasi dari ide dasar di atas ke dalam script PHP adalah seperti di bawah ini.

<?php

// parameter koneksi ke MySQL
$dbhost = "localhost";
$dbuser = "...";
$dbpass = "...";
$dbname = "...";

// koneksi ke mysql
$conn = mysqli_connect($dbhost, $dbuser, $dbpass, $dbname);

// query untuk membaca semua data record
$query = "SELECT * FROM zip";
// jalankan query
$result = mysqli_query($conn, $query);

// proses looping untuk setiap data hasil query
while ($data = mysqli_fetch_assoc($result)){
	// membuat array asosiatif untuk setiap data
	$item = array("id" => $data['id'],
                      "city" => $data['city'],
                      "loc" => array(doubleval($data['lat']), doubleval($data['long'])),
                      "pop" => intval($data['pop']),
                      "state" => $data['state']);
	// proses encode array asosiatif ke json
	// lalu tampilkan 
	echo json_encode($item)."\n";
}

// tutup koneksi
mysqli_close($conn);
?>

Struktur array asosiatif yang menjadi acuan untuk membuat JSON adalah seperti berikut ini

$item = array("id" => $data['id'], 
              "city" => $data['city'],
              "loc" => array(doubleval($data['lat']), doubleval($data['long'])),
              "pop" => intval($data['pop']),
              "state" => $data['state']);

Dalam hal ini, pemberian nama key dari array asosiatif tersebut nantinya akan menjadi key dari JSON nya.

Khusus untuk key ‘loc’ (location), disini valuenya merupakan array yang elemennya merupakan gabungan dari latitude dan longitude.

Adapun function doubleval() digunakan untuk mengubah data string menjadi double. Hal ini dilakukan karena secara default tipe data hasil query select table di PHP adalah string. Demikian pula function intval(), yaitu berguna untuk mengubah tipe data string menjadi integer.

Apabila script PHP di atas dijalankan, maka akan dihasilkan tampilan halaman berisi JSON seperti di bawah ini.

JSON hasil generate

 


Author

Comments

Write a Reply or Comment

Your email address will not be published.