↑ Return to Buku PHP & MySQL

Input Data Ke MySQL Secara Simultan Via Form dengan PHP

Input Data Ke MySQL Secara Simultan Via Form dengan PHP

Posted By rosihanari On September 14, 2009 @ 2:05 pm In PHP | Comments Disabled

Seringkali kita membuat script untuk input data hanya terdiri dari sebuah data atau record saja. Itu sangat-sangat mudah dilakukan. Lantas, bagaimana bila sekali entri langsung beberapa record sekaligus secara simultan? Dengan demikian kita bisa entri beberapa data sekaligus tanpa repot bolak-balik membuka form baru ketika mau menyisipkan data. Kira-kira hal ini bisa dilakukan nggak ya? He.. 3x… Ya jelas bisa donk! Oleh karena itu akan saya paparkan bagaimana ide membuat script seperti itu dengan PHP melalui artikel ini.

Sebelum kita mulai membahas cara pembuatannya, ada baiknya Anda simak gambar berikut ini yang merupakan grand design studi kasus yang akan kita buat sebagai contoh input data simultan [1] ini. Studi kasus yang saya ambil terkait dengan entri data mahasiswa.

Pertama, user diminta memasukkan jumlah data yang mau dientri terlebih dahulu (lihat gambar di bawah ini)

input data form simultan

Kedua, setelah user memasukkan jumlah data yang mau dientri, selanjutnya muncul form dengan komponen entri sejumlah data yang tadi dimasukkan. Pada form inilah data yang mau disimpan ke database, dimasukkan.

input data form simultan

Setelah form di atas disubmit, maka data akan tersimpan ke database, seperti tampak pada gambar berikut ini

input data form simultan

Nah… bagaimana cara membuatnya?

Pertama kita siapkan dahulu tabel database MySQL nya. Pada studi kasus ini, kita buat simpel saja deh (cukup 2 field saja dulu)

CREATE TABLE mhs (
nim varchar(5),
namamhs varchar(20),
PRIMARY KEY (nim)
);

Kemudian kita buat form untuk memasukkan jumlah datanya terlebih dahulu.

form.html

Input Data Mahasiswa

Jumlah Data

Saya kira untuk membuat form di atas tidak ada masalah kan? :-)

Berikutnya kita buat script untuk menampilkan komponen inputnya sejumlah data yang tadi dimasukkan pada form di atas. Konsepnya adalah kita gunakan looping untuk menampilkan komponen inputnya. Lantas… loopingnya dilakukan berapa kali? ya… sebanyak jumlah datanya donk.

submit.php

Input Data Mahasiswa

<?php
$n = $_POST['jum']; // membaca jumlah data

for ($i=1; $i<=$n; $i++)
{
echo "

“;
}
?>

NIM NAMA MHS

<input type="hidden" name="jum" value="”>

Bila Anda perhatikan script di atas, maka nama komponen untuk input NIM berbentuk

yang mana nantinya looping ($i=1, 2, 3, …, $n) akan membentuk komponen-komponen dengan nama

.
.
dst

Nah… hal yang sama kita buat juga untuk komponen input nama mahasiswa.

Kemudian, coba perhatikan pula bahwa di bagian akhir script terdapat perintah

<input type="hidden" name="jum" value="”>

Perintah tersebut akan menghasilkan komponen hidden untuk menyimpan nilai $n (banyaknya data). Nilai ini nanti akan ikut disubmit ke script berikutnya guna pemrosesan lebih lanjut.

Terakhir.. kita buat script untuk insert datanya. Untuk membuat script insert data secara simultan ini, mungkin yang menjadi kendala adalah bagaimana cara membaca semua data yang telah diinputkan dalam form sebelumnya untuk kemudian disimpan ke dalam database. Adapun konsep pembacaan datanya adalah dengan menggunakan looping juga. Looping ini dilakukan sebanyak jumlah datanya ($n). Oleh karena itulah pada script ini kita butuh nilai $n yang ikut tersubmit dari script sebelumnya.

insert.php

<?php

// koneksi ke mysql
mysql_connect("dbhost", "dbuser", "dbpass");
mysql_select_db("dbname");

$n = $_POST['jum']; // membaca jumlah data

// looping
for ($i=1; $i<=$n; $i++)
{
$datanim = $_POST['nim'.$i];
$datanama = $_POST['nama'.$i];

if ((!empty($datanim)) && (!empty($datanama)))
{
$query = "INSERT INTO mhs (nim, namamhs) VALUES ('$datanim', '$datanama')";
$hasil = mysql_query($query);

if ($hasil) echo "Input data sukses
“;
else echo “Input data gagal
“;
}
}

?>

Perhatikan perintah $datanim = $_POST[‘nim’.$i]; yang terdapat dalam looping di atas. Perintah tersebut digunakan untuk membaca value yang diinputkan dari komponen form bernama ‘nim1‘, ‘nim2‘, … dst. Hal yang sama juga berlaku untuk perintah $datanama = $_POST[‘nama’.$i];. Setelah value NIM dan Nama Mhs dari komponen pertama (‘nim1‘ dan ‘nama1‘) dibaca, selanjutnya baru disimpan ke database. Kemudian pembacaan dan insert data ke database dilanjutkan pada komponen kedua (‘nim2‘ dan ‘nama2‘), begitu seterusnya sampai dengan komponen terakhir.

Oya.. tambahan lagi, dalam script di atas juga terdapat statement

if ((!empty($datanim)) && (!empty($datanama)))
{

}

Statement tersebut digunakan untuk mengecek jika ada baris komponen form yang tidak diisi NIM maupun nama mahasiswanya. Proses insert data ke database hanya akan dilakukan bila komponen input NIM dan nama mahasiswanya tidak kosong.

OK deh… demikian tadi ide untuk membuat script insert data ke database MySQL secara simultan melalui form dengan script PHP [1]. Mudah-mudahan ada manfaatnya.

Oya, Anda juga bisa membaca artikel saya yang lain tentang cara update data secara simultan [

Leave a Reply

Your email address will not be published. Required fields are marked *


*

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>