Cara Membuat Advance Paging dengan PHP
Pada kesempatan kali ini daesoft akan membahas bagaimana cara membuat advance panging pada PHP. Fungsi utama dari advance pagging adalah untuk mengurangi scroling windows apabila data yang dimuat terlalu banyak. selain itu juga penggunaan advance pagging dapat mempercepat load time page, sehingga halaman yang dimuat relative lebih cepat.
Advance pagging yang akan dibuat pada tutoral kali ini adalah seperti dibawah ini :
1 2 3 4 … 20 Next >>
Tahap pertama silahkan buat tabel untuk meyimpan data :
- CREATE TABLE guestbook (
- id int(11) auto_increment,
- nama varchar(20),
- email varchar(20),
- tanggal date,
- komentar text,
- PRIMARY KEY (id)
- )
Selanjutnya buat halaman koneksi dengan nama show.php
- <?php
- // koneksi ke mysql
- mysql_connect('namahost', 'dbuser', 'dbpassword');
- mysql_select_db(data);
- // jumlah data yang akan ditampilkan per halaman
- $dataPerPage = 5;
- ?>
Kita lanjutkan skenarionya. Untuk script paging ini, bila dibuka pertama kali dengan URL http://namaserver/show.php maka otomatis menuju ke halaman 1. Untuk menuju ke halaman 2, maka URL nya http://namaserver/show.php?page=2. Sedangkan untuk menuju ke halaman 3, URL nya http://namaserver/show.php?page=3, dan seterusnya.
Dari skenario di atas tampak bahwa bila parameter ?page=... belum diberikan pada URL maka secara otomatis menuju ke nomor halaman 1. Sedangkan bila terdapat parameter ?page=… maka nomor halamannya menyesuaikan nilai pada parameter ?page tersebut. Untuk mewujudkan hal ini, maka kita tambahkan perintah
- <?php
- mysql_connect('namahost', 'dbuser', 'dbpassword');
- mysql_select_db('dbname');
- // jumlah data yang akan ditampilkan per halaman
- $dataPerPage = 5;
- // apabila $_GET['page'] sudah didefinisikan, gunakan nomor halaman tersebut,
- // sedangkan apabila belum, nomor halamannya 1.
- if(isset($_GET['page']))
- {
- $noPage = $_GET['page'];
- }
- else $noPage = 1;
- ?>
Selanjutnya, dalam teknik paging perlu adanya pengaturan posisi awal data atau lebih dikenal dengan istilah offset. Offset digunakan untuk mengatur posisi awal data yang akan ditampilkan perhalaman. Perlu Anda tahu, bahwa data dalam database memiliki urutan seperti halnya array. Data pada baris pertama hasil query SQL disebut data pada posisi ke-0, data pada baris kedua disebut data pada posisi ke-1, dst.
Trus.. apa kaitannya offset dengan paging? Sabar… perhatikan dulu contoh berikut ini
Sebagai contoh, misalkan terdapat 15 data dalam tabel guestbook dimana kita ingin menyajikan pada setiap halaman adalah 5 data. Dengan demikian total terdapat 3 halaman dalam pagingnya. Untuk halaman pertama, pastilah data yang ditampilkan adalah data ke – 0, 1, 2, 3 dan 4. Sedangkan halaman kedua, data yang ditampilkan adalah 5, 6, 7, 8, dan 9. Serta halaman ketiga, data ke 10, 11, 12, 13, 14.
Nah… perhatikan bahwa untuk halaman 1, data awal yang ditampilkan adalah data pada urutan ke-0, halaman 2 data awalnya adalah data pada urutan ke-5 dan halaman 3 data pada urutan ke 10.
Lantas apa gunanya offset tersebut? Offset nantinya akan digunakan pada query SQL untuk memunculkan data pada setiap halaman. Query SQL yang digunakan adalah
- SELECT * FROM guestbook LIMIT offset, jumlahData;
Sehingga untuk memunculkan data guestbook pada halaman pertama, maka perintahnya
- SELECT * FROM guestbook LIMIT 0, 5;
- SELECT * FROM guestbook LIMIT 5, 5;
offset = (no halaman – 1) * jumlah data per halaman;
Lho kok bisa? he.. 3x kita cek saja. Untuk halaman 1, maka nilai offset = (1 – 1) * 5 = 0. Untuk halaman 2, nilai $offset = (2 – 1) * 5 = 5 dan halaman ketiga $offset = (3 – 1) * 5 = 10. Bener kan?
OK.. deh, dah paham tentang offset, so.. kita bisa tambahkan scriptnya untuk mencari offset dan query SQL nya.
- <?php
- mysql_connect('namahost', 'dbuser', 'dbpassword');
- mysql_select_db('dbname');
- // jumlah data yang akan ditampilkan per halaman
- $dataPerPage = 5;
- // apabila $_GET['page'] sudah didefinisikan, gunakan nomor halaman tersebut,
- // sedangkan apabila belum, nomor halamannya 1.
- if(isset($_GET['page']))
- {
- $noPage = $_GET['page'];
- }
- else $noPage = 1;
- // perhitungan offset
- $offset = ($noPage - 1) * $dataPerPage;
- // query SQL untuk menampilkan data perhalaman sesuai offset
- $query = "SELECT * FROM guestbook LIMIT $offset, $dataPerPage";
- $result = mysql_query($query) or die('Error');
- // menampilkan data
- echo "<table border='1'>";
- echo "<tr><td>Nama</td><td>Email</td><td>Tanggal</td><td>Komentar</td></tr>";
- while($data = mysql_fetch_array($result))
- {
- echo "<tr><td>".$data['nama']."</td><td>".$data['email']."</td><td>".$data['tanggal']."</td><td>".$data['komentar']."</td></tr>";
- }
- echo "</table>";
- .
- .
- ?>
Nah… masalah berikutnya adalah bagaimana menentukan total jumlah halamannya? Hal ini penting karena nantinya akan ditampilkan sebagai link navigasi pagingnya. Untuk menghitung total jumlah halaman, kita cari patternnya terlebih dahulu. Misalkan terdapat 15 data, dan kita ingin menyajikan data sejumlah 5 per halaman, maka total ada berapa halaman yang dibutuhkan? OK.. benar ada 3. Trus… kalo ada 31 data dan kita ingin menyajikan data sejumlah 5 per halaman, total ada berapa halaman? OK.. benar ada 7 (untuk halaman ke-7 hanya tampil 1 buah data). Sehingga dari pattern tersebut formula untuk menghitung jumlah halaman adalah
jumlah halaman = ceil(jumlah data / data per halaman);
ceil() adalah function yang digunakan untuk membulatkan ke atas suatu bilangan. Misal ceil(3.2) = 4, ceil(3.7) = 4.
Trus… yang jadi masalah adalah bagaimana mendapatkan jumlah datanya? Nah… untuk mendapatkan jumlah data keseluruhan yang ada kita gunakan query SQL.
- SELECT COUNT(*) FROM guestbook;
- <?php
- mysql_connect('namahost', 'dbuser', 'dbpassword');
- mysql_select_db('dbname');
- // jumlah data yang akan ditampilkan per halaman
- $dataPerPage = 5;
- // apabila $_GET['page'] sudah didefinisikan, gunakan nomor halaman tersebut,
- // sedangkan apabila belum, nomor halamannya 1.
- if(isset($_GET['page']))
- {
- $noPage = $_GET['page'];
- }
- else $noPage = 1;
- // perhitungan offset
- $offset = ($noPage - 1) * $dataPerPage;
- // query SQL untuk menampilkan data perhalaman sesuai offset
- $query = "SELECT * FROM guestbook LIMIT $offset, $dataPerPage";
- $result = mysql_query($query);
- // menampilkan data
- echo "<table border='1'>";
- echo "<tr><td>Nama</td><td>Email</td><td>Tanggal</td><td>Komentar</td></tr>";
- while($data = mysql_fetch_array($result))
- {
- echo "<tr><td>".$data['nama']."</td><td>".$data['email']."</td><td>".$data['tanggal']."</td><td>".$data['komentar']."</td></tr>";
- }
- echo "</table>";
- // mencari jumlah semua data dalam tabel guestbook
- $query = "SELECT COUNT(*) AS jumData FROM guestbook";
- $hasil = mysql_query($query);
- $data = mysql_fetch_array($hasil);
- $jumData = $data['jumData'];
- // menentukan jumlah halaman yang muncul berdasarkan jumlah semua data
- $jumPage = ceil($jumData/$dataPerPage);
- .
- .
- ?>
Nah… sekarang tinggal bagaimana cara memunculkan link berisi nomor halaman yang menuju ke setiap halamannya. Untuk memunculkan nomor halamannya, caranya mudah. Kita hanya menggunakan looping saja.
Tapi eit.. tunggu dulu pada desain advance paging di atas, sebelum memunculkan link nomor halaman, terdapat link << prev. Kapan link ini akan muncul? ya... tepat sekali yaitu ketika nomor halaman yang sedang aktif (sedang dibuka) setelah halaman pertama atau $noPage > 1. Trus.. menuju ke nomor halaman berapakah link tersebut? yap.. benar yaitu menuju ke nomor halaman sebelumnya ($noPage – 1).
Dengan demikian kita bisa tambahkan perintah berikut ini pada script
- if ($noPage > 1) echo "<a href='".$_SERVER['PHP_SELF']."?page=".($noPage-1)."'><< Prev</a>";
- <?php
- mysql_connect('namahost', 'dbuser', 'dbpassword');
- mysql_select_db('dbname');
- // jumlah data yang akan ditampilkan per halaman
- $dataPerPage = 5;
- // apabila $_GET['page'] sudah didefinisikan, gunakan nomor halaman tersebut,
- // sedangkan apabila belum, nomor halamannya 1.
- if(isset($_GET['page']))
- {
- $noPage = $_GET['page'];
- }
- else $noPage = 1;
- // perhitungan offset
- $offset = ($noPage - 1) * $dataPerPage;
- // query SQL untuk menampilkan data perhalaman sesuai offset
- $query = "SELECT * FROM guestbook LIMIT $offset, $dataPerPage";
- $result = mysql_query($query) or die('Error');
- // menampilkan data
- echo "<table border='1'>";
- echo "<tr><td>Nama</td><td>Email</td><td>Tanggal</td><td>Komentar</td></tr>";
- while($data = mysql_fetch_array($result))
- {
- echo "<tr><td>".$data['nama']."</td><td>".$data['email']."</td><td>".$data['tanggal']."</td><td>".$data['komentar']."</td></tr>";
- }
- echo "</table>";
- // mencari jumlah semua data dalam tabel guestbook
- $query = "SELECT COUNT(*) AS jumData FROM guestbook";
- $hasil = mysql_query($query);
- $data = mysql_fetch_array($hasil);
- $jumData = $data['jumData'];
- // menentukan jumlah halaman yang muncul berdasarkan jumlah semua data
- $jumPage = ceil($jumData/$dataPerPage);
- // menampilkan link previous
- if ($noPage > 1) echo "<a href='".$_SERVER['PHP_SELF']."?page=".($noPage-1)."'><< Prev</a>";
- .
- .
- ?>
- for($page = 1; $page <= $jumPage; $page++)
- {
- if ((($page >= $noPage - 3) && ($page <= $noPage + 3)) || ($page == 1) || ($page == $jumPage))
- {
- if (($showPage == 1) && ($page != 2)) echo "...";
- if (($showPage != ($jumPage - 1)) && ($page == $jumPage)) echo "...";
- if ($page == $noPage) echo " <b>".$page."</b> ";
- else echo " <a href='".$_SERVER['PHP_SELF']."?page=".$page."'>".$page."</a> ";
- $showPage = $page;
- }
- }
- if ($noPage < $jumPage) echo "<a href='".$_SERVER['PHP_SELF']."?page=".($noPage+1)."'>Next >></a>";
- <?php
- mysql_connect('namahost', 'dbuser', 'dbpassword');
- mysql_select_db('dbname');
- // jumlah data yang akan ditampilkan per halaman
- $dataPerPage = 5;
- // apabila $_GET['page'] sudah didefinisikan, gunakan nomor halaman tersebut,
- // sedangkan apabila belum, nomor halamannya 1.
- if(isset($_GET['page']))
- {
- $noPage = $_GET['page'];
- }
- else $noPage = 1;
- // perhitungan offset
- $offset = ($noPage - 1) * $dataPerPage;
- // query SQL untuk menampilkan data perhalaman sesuai offset
- $query = "SELECT * FROM guestbook LIMIT $offset, $dataPerPage";
- $result = mysql_query($query) or die('Error');
- // menampilkan data
- echo "<table border='1'>";
- echo "<tr><td>Nama</td><td>Email</td><td>Tanggal</td><td>Komentar</td></tr>";
- while($data = mysql_fetch_array($result))
- {
- echo "<tr><td>".$data['nama']."</td><td>".$data['email']."</td><td>".$data['tanggal']."</td><td>".$data['komentar']."</td></tr>";
- }
- echo "</table>";
- // mencari jumlah semua data dalam tabel guestbook
- $query = "SELECT COUNT(*) AS jumData FROM guestbook";
- $hasil = mysql_query($query);
- $data = mysql_fetch_array($hasil);
- $jumData = $data['jumData'];
- // menentukan jumlah halaman yang muncul berdasarkan jumlah semua data
- $jumPage = ceil($jumData/$dataPerPage);
- // menampilkan link previous
- if ($noPage > 1) echo "<a href='".$_SERVER['PHP_SELF']."?page=".($noPage-1)."'><< Prev</a>";
- // memunculkan nomor halaman dan linknya
- for($page = 1; $page <= $jumPage; $page++)
- {
- if ((($page >= $noPage - 3) && ($page <= $noPage + 3)) || ($page == 1) || ($page == $jumPage))
- {
- if (($showPage == 1) && ($page != 2)) echo "...";
- if (($showPage != ($jumPage - 1)) && ($page == $jumPage)) echo "...";
- if ($page == $noPage) echo " <b>".$page."</b> ";
- else echo " <a href='".$_SERVER['PHP_SELF']."?page=".$page."'>".$page."</a> ";
- $showPage = $page;
- }
- }
- // menampilkan link next
- if ($noPage < $jumPage) echo "<a href='".$_SERVER['PHP_SELF']."?page=".($noPage+1)."'>Next >></a>";
- ?>
Tidak ada komentar