php tutorial in youtube,php tutorial intermediate,sql i php tutorial,tutorial php javascript mysql,tutorial php json,tutorial php jquery,tutorial php javascript,tutorial php jwt,tutorial php jquery ajax,tutorial php java bridge,tutorial json php mysql,tutorial jenkins php,tutorial jquery php mysql,tutorial koneksi php mysql,tutorial koneksi php,tutorial coding php,calendar php tutorial,tutorial koneksi php ke mysql,tutorial koneksi php ke database mysql,php klein tutorial,php kafka tutorial,kumpulan tutorial php,tutorial cara membuat koneksi php dengan database mysql,k php tutorial,tutorial php login,tutorial php lengkap bahasa pemrograman php belajar php pdf,tutorial php laravel,tutorial php login session,tutorial php login & registration,tutorial php linux,tutorial php lengkap untuk pemula,tutorial php lengkap bahasa indonesia,tutorial php login system,tutorial php membuat website,tutorial php mysql bahasa indonesia pdf,tutorial php mvc,my php tutorial,php and mysql tutorial pdf,phpmyadmin database tutorial,phpmyadmin tutorial pdf,tutorial menggunakan phpmyadmin,mysql phpmyadmin tutorial,tutorial php netbeans,tutorial php namespace,tutorial php.net,tutorial php notepad++,tutorial php netbeans pdf,tutorial php nusoap,tutorial php netbeans español,tutorial nginx php,php mysqli tutorial,tutorial php online,tutorial php object oriented programming,php oop tutorial,tutorial php oracle,tutorial php oop pdf,tutorial php oop mvc,tutorial php oop programming,tutorial php oop crud,tutorial php online shop,tutorial php pemula,tutorial php pdo,tutorial php pdf bahasa indonesia,tutorial php pdo indonesia,tutorial php postgresql,tutorial php programming,tutorial php project,tutorial php postgresql pdf,tutorial php query mysql,php tutorial quiz,php tutorial quick,php tutorial query,php qt tutorial,php barcode tutorial,php tutorial quora,php tutorial questions and answers,php tutorial quakenet,php tutorial query database,tutorial php rest api,tutorial php report maker,tutorial php runner,tutorial php redis,tutorial php report maker pdf,tutorial php register,tutorial php regular expression,tutorial republic php,tutorial regex php,php tutorial restful web services,php-r tutorial,tutorial php source code aplikasi pemesanan tiket bus online - gratis,tutorial php socket,tutorial php switch,tutorial php soap,tutorial php storm,tutorial php sql,tutorial php symfony,tutorial php session,tutorial php sqlite,tutorial php to pdf,tutorial php telegram bot,tutorial php to excel,php tutorial tutorialspoint pdf,tutorial twig php,php tutorial tizag,php tutorial template,tutorial to php,php tutorial to send email,phpunit test tutorial,tutorial php untuk pemula,tutorial php unit,tutorial php unit testing phpunit laravel,tutorial php upload file,tutorial php ubuntu,tutorial php upload image,tutorial php untuk membuat website,tutorial php update insert delete and search,php tutorial udemy,tutorial php video,tutorial php validation form,php tutorial video free download,php tutorial video download,php tutorial video youtube,php tutorial variables,php tutorial visual studio,best php tutorial videos,best php tutorial video,php varnish tutorial,tutorial php w3schools,tutorial php wordpress,tutorial php website,tutorial php web service,tutorial php websocket,tutorial php web application,tutorial php with mysql,tutorial php windows,tutorial php website template,tutorial php with xampp,kalendarz w php tutorial,tworzenie stron w php tutorial,tutorial php xml,tutorial php xampp pdf,tutorial xampp php mysql,tutorial xpath php,tutorial xdebug php,tutorial php mysql xampp pdf,php xml reader tutorial,php xmlwriter tutorial,tutorial php youtube,tutorial php yii,youtube tutorial php,tutorial php y mysql,tutorial php y mysql pdf,tutorial php y mysql completo,tutorial php ya,php tutorial youtube video,php tutorial secure your login form using tokens,oop php tutorial youtube,mysql y php tutorial,tutorial php y mysqli,tutorial php y mysql netbeans,html5 y php tutorial,tutorial php y html,tutorial php y postgresql pdf,tutorial php y mysql youtube,tutorial php y mysql español,tutorial php zend framework,php tutorial zend,php tutorial zip,php ziparchive tutorial,php zlib tutorial,php tutorial za pocetnike,php tutorial using zend framework,php zeromq tutorial,php zend tutorial pdf,php zeiterfassung tutorial,a to z php tutorial,php 000webhost tutorial,tutorial php desde 0,php tutorial 101,tutorial belajar php part 1,php tutorial 1,cakephp 1.3 tutorial,tutorial php 2018,tutorial php 2017,tutorial phpmaker 2018,php tutorial 2018,php tutorial 2017 pdf,php tutorial 2016,php tutorial 2,cakephp 2.x tutorial,best php tutorial 2017,doctrine 2 php tutorial,oauth2 php tutorial,angular 2 tutorial php,angularjs 2 tutorial php,magento 2 php tutorial,php symfony2 tutorial,ionic 2 php tutorial,2 dimensional array php tutorial,phpdocumentor 2 tutorial,2 factor authentication php tutorial,tutorial cakephp 3,php tutorial 3school,php tutorial 3w,php 3 tutorial,slim 3 php tutorial,sqlite3 php tutorial,openshift 3 php tutorial,aptana studio 3 tutorial php,symfony 3 php tutorial,symphony 3 php tutorial,aptana studio 3 tutorial php pdf,sublime text 3 tutorial php,php tutorial 4,angular 4 tutorial php,psr-4 php tutorial,symfony 4 php tutorial,symphony 4 php tutorial,php 4 tutorial,phpunit 4 tutorial,tutorial php 5.6,php5 tutorial pdf,tutorial php 5.5,tutorial php 5.5 pdf,php 5.6 tutorial pdf,php5 tutorial point,php5 tutorial pdf download,php 5.3 tutorial,php 5.3 tutorial pdf,php5 tutorial - w3schools,laravel 5 phpunit tutorial,laravel 5 php tutorial,php 5 tutorial,angular 5 php tutorial,phpunit 5 tutorial,facebook sdk 5 php tutorial,php 6 tutorial pdf,phpmailer 6 tutorial,php 6 tutorial,phpunit 6 tutorial,tutorial #6 esp8266 - mysql + php en servidor local,tutorial php 7 bahasa indonesia pdf,tutorial php 7 mysql,tutorial php 7.0,tutorial php 7 español,tutorial crud php 7,tutorial point php 7,tutorial belajar php 7,php 7 tutorial w3schools,psr-7 tutorial php,php 7 tutorial,php 7 tutorial pdf,php 7 tutorial point,php 7 tutorial mysql,php 8 tutorial,tutorial phprunner 8,drupal 8 phpunit tutorial,drupal 8 php tutorial,dreamweaver 8 php tutorial pdf,php designer 8 tutorial,php designer 8 tutorial pdf,macromedia dreamweaver 8 php tutorial,phpmaker 9 tutorial,cloud 9 php tutorial,phprunner 9 tutorial,phpmaker 9 tutorial pdf,phpstorm 9 tutorial,tutorial php,tutorial php mysql,tutorial php native,tutorial php pdf,tutorial php dan mysql,tutorial php codeigniter,tutorial php lengkap,tutorial phpmaker pdf,tutorial phpmyadmin,tutorial php api,tutorial php advanced,tutorial php array,tutorial php ajax,tutorial php admin,tutorial php apache,tutorial php ajax jquery,tutorial php ajax mysql,a php tutorial for beginners,a complete php tutorial,a complete php tutorial pdf,tutorial php bahasa indonesia,tutorial php bagi pemula,tutorial php blog,tutorial php beginner,tutorial php backend,tutorial php bot telegram,tutorial php blockchain,tutorial php basico,php tutorial by tizag,tutorial php codeigniter pdf,tutorial php codeigniter bahasa indonesia,tutorial php curl,tutorial php connect mysql,tutorial php class,tutorial php composer,tutorial php contact form,tutorial php dasar,tutorial php dreamweaver cs6,tutorial php dan mysql lengkap,tutorial php dengan dreamweaver,tutorial php dasar lengkap pdf,tutorial php database,tutorial php duniailkom,tutorial php dreamweaver,tutorial php dasar pdf,tutorial di php,tutorial php excel,tutorial php eclipse,tutorial php en pdf,tutorial php ecommerce,tutorial php en netbeans,tutorial php editor,tutorial php ebook,tutorial php email form,tutorial php echo,tutorial php español,e commerce tutorial php,e commerce website tutorial php,mysql e php tutorial,e commerce website php tutorial download,ecommerce cart php tutorial,e-shop php tutorial,tutorial php framework,tutorial php form,tutorial php framework laravel,tutorial php for beginners,tutorial php framework codeigniter,tutorial php facebook api,tutorial php firebase,tutorial php-fpm,tutorial php foreach,tutorial php file upload,tutorial php generator for mysql,tutorial php gtk,tutorial php generator for mysql professional,tutorial php graphql,tutorial php grid,php tutorial github,php tutorial get,tutorial gammu php mysql,php tutorial get post,tutorial gettext php,tutorial php html,tutorial php html mysql,tutorial php html css,tutorial php html5,php tutorial hello world,tutorial highcharts php mysql,tutorial htaccess php,php tutorial home and learn,tutorial heroku php,tutorial html2pdf php,tutorial php indonesia,tutorial php indonesia pdf,tutorial php injection,tutorial php.ini,tutorial php include,tutorial php it,php tutorial in w3schools,php tutorial interactive

codeigniter https,codeigniter hooks,codeigniter html2pdf,codeigniter hack,codeigniter hmvc template,codeigniter harviacode,codeigniter h,codeigniter insert,codeigniter insert batch,codeigniter insert_id,codeigniter inner join,codeigniter insert data,codeigniter ion auth,codeigniter import excel,codeigniter insert id,codeigniter install,session i codeigniter,for loop i codeigniter,codeigniter join,codeigniter join table,codeigniter jwt,codeigniter json,codeigniter jquery,codeigniter jquery ajax post data,codeigniter javascript,codeigniter join 2 table,codeigniter jwt tutorial,codeigniter json output,jquery in codeigniter,codeigniter kirim email,codeigniter kelebihan,codeigniter kaskus,codeigniter koneksi 2 database,codeigniter keuangan,codeigniter kenjis,codeigniter koolreport,codeigniter kint,codeigniter key generator,codeigniter keep form values after submit,codeigniter like,codeigniter left join,codeigniter last insert id,codeigniter library,codeigniter logo,codeigniter language,codeigniter login user level,codeigniter logo png,codeigniter load view,codeigniter l,codeigniter model,codeigniter multiple upload,codeigniter mongodb,codeigniter menurut para ahli,codeigniter multiple database,codeigniter mpdf,codeigniter migration,codeigniter mysqli,codeigniter mvc,fpdf codeigniter,codeigniter num_rows,codeigniter nginx,codeigniter not found,codeigniter news,codeigniter no input file specified,codeigniter notification,codeigniter nodejs,codeigniter number format,codeigniter num row,codeigniter news portal,codeigniter in php,replace in codeigniter,codeigniter order by,codeigniter online shop,codeigniter order by desc,codeigniter output,codeigniter orm,codeigniter or where,codeigniter only variable references should be returned by reference,codeigniter oracle,codeigniter oauth2,codeigniter or laravel,codeigniter o laravel,codeigniter o que é,codeigniter o symfony,usando o codeigniter,configurando o codeigniter,yii or codeigniter,o'reilly codeigniter,como usar o codeigniter,como instalar o codeigniter,como funciona o codeigniter,codeigniter pdf,codeigniter php,codeigniter php 7,codeigniter postgresql,codeigniter print pdf,codeigniter pagination example,codeigniter pdf library,codeigniter project,codeigniter post,codeigniter p,codeigniter qr code,codeigniter query string,codeigniter query like,codeigniter query count,codeigniter query limit,codeigniter query insert,codeigniter query builder join,codeigniter qr code example,codeigniter q&a,codeigniter redirect,codeigniter remove index.php,codeigniter result,codeigniter rest client,codeigniter route,codeigniter react,codeigniter rental mobil,codeigniter report generator,print_r codeigniter,codeigniter r n,r&os pdf codeigniter,codeigniter send email,codeigniter select,codeigniter select count,codeigniter sendgrid,codeigniter send email gmail,codeigniter session not working,codeigniter socket io,codeigniter sql server,codeigniter sql injection,codeigniter tutorial pdf,codeigniter transaction,codeigniter template bootstrap,codeigniter terbaru,codeigniter timezone,codeigniter truncate table,codeigniter template engine,codeigniter templating,codeigniter t,codeigniter t shirt,codeigniter t_const,codeigniter t point,codeigniter update,codeigniter user guide,codeigniter upload foto,codeigniter uri,codeigniter update database,codeigniter url,codeigniter unlink,codeigniter update data,codeigniter update batch,codeigniter validation,codeigniter vue,codeigniter vue js,codeigniter view,codeigniter vs,codeigniter vs laravel 2018,codeigniter versi terbaru,codeigniter visitor statistics,codeigniter vs yii,codeigniter v 2.1.4,codeigniter or cakephp,fuelphp vs codeigniter,codeigniter where,codeigniter where not,codeigniter where between,codeigniter websocket,codeigniter where or,codeigniter web service,codeigniter website,codeigniter where in array,codeigniter where not null,codeigniter xss_clean,codeigniter xml,codeigniter xss,codeigniter xampp,codeigniter xml parser,codeigniter xlsx,codeigniter x-www-form-urlencoded,codeigniter xmlrpc,codeigniter xlsx reader,codeigniter xdebug,codeigniter x-editable,codeigniter x-mailer,x-editable codeigniter example,x-api-key codeigniter,x-xss-protection codeigniter,codeigniter x laravel,codeigniter x-forwarded-for,codeigniter 2.x,codeigniter youtube,codeigniter you did not select a file to upload,codeigniter your system folder path does not appear to be set correctly,codeigniter you have specified an invalid database connection group,codeigniter your view folder path does not appear to be set correctly,codeigniter yield,codeigniter you don't have permission to access,codeigniter you have not selected a database type to connect to,codeigniter yt,codeigniter you don't have permission to access the requested object,codeigniter y bootstrap,ajax in codeigniter,codeigniter and angularjs,angular and codeigniter,codeigniter y postgresql,codeigniter y php,codeigniter y php 7,codeigniter y vue,codeigniter y oracle,codeigniter y firebase,codeigniter zip multiple files,codeigniter zip,codeigniter zip file download,codeigniter zend library,codeigniter zip add data,codeigniter zip archive,codeigniter zip folder,codeigniter zend barcode,codeigniter zip download,codeigniter zoho mail,codeigniter 000webhost,codeigniter 0day,codeigniter where 0,codeigniter undefined offset 0,codeigniter return $_config 0 =& $config,codeigniter duplicate entry '0' for key 'primary',codeigniter error reporting 0,dompdf 0.8.2 codeigniter,codeigniter cart price 0,codeigniter row(0),undefined offset 0 codeigniter,error reporting 0 codeigniter,error number 0 codeigniter,row(0) codeigniter,codeigniter 1.7.2,codeigniter 1.7.2 download,codeigniter 1.7.3,codeigniter 1.7,codeigniter 1.7 documentation,codeigniter 1.7.2 documentation,codeigniter 1 documentation,codeigniter 1.0,codeigniter 1.7.2 user guide,codeigniter 1.7.3 download,1 codeigniter redirect,codeigniter $1 route,http // 1 / codeigniter,limit 1 codeigniter,top 1 codeigniter,remove 1 codeigniter,missing argument 1 codeigniter,undefined offset 1 codeigniter,codeigniter 2.1.4,codeigniter 2.2.6,codeigniter 2018,codeigniter 2 database,codeigniter 2.2,codeigniter 2.1.3,codeigniter 2.2 stable,codeigniter 2 download,codeigniter 2 documentation,codeigniter 2,codeigniter 2 form validation,codeigniter 2 session,codeigniter 2 docs,codeigniter 2 to 3,codeigniter 3.1.9,codeigniter 3 tutorial,codeigniter 3 tutorial pdf,codeigniter 3.1.8,codeigniter 3 hmvc,codeigniter 3 multiple database,codeigniter 3 ebook,codeigniter 3.1.6,codeigniter 3 crud,codeigniter 3.1.7,codeigniter 3,codeigniter 3 htaccess,codeigniter 3 login,codeigniter 3 form validation,codeigniter 3 php 7,codeigniter 3 multiple file upload,codeigniter 404 page not found,codeigniter 4 tutorial,codeigniter 404,codeigniter 4 release date,codeigniter 404 hosting,codeigniter 4 download,codeigniter 403 forbidden,codeigniter 4 release,codeigniter 4 documentation,codeigniter 404 page not found localhost,codeigniter 4 vs laravel,codeigniter 4 features,codeigniter 4 hmvc,codeigniter 4 docs,codeigniter 500 internal server error,codeigniter 500,codeigniter 503 service unavailable,codeigniter 500 internal server error ubuntu,codeigniter 500 error loading model,codeigniter 502 bad gateway,codeigniter 500 error,codeigniter 500 error page,codeigniter 500 internal server error .htaccess,codeigniter 504 gateway timeout,codeigniter 5,angular 5 codeigniter,sximo 5 codeigniter,facebook sdk 5 codeigniter,undefined offset 5 codeigniter,codeigniter 5 star rating system,html5 codeigniter form,codeigniter 64 bit,6 codeigniter hacks,codeigniter centos 6,codeigniter phpmailer 6,base64 codeigniter,codeigniter mpdf 6,6 codeigniter hacks for the masters,codeigniter foundation 6,extjs 6 codeigniter,phpmailer 6 codeigniter,codeigniter 6,foundation 6 codeigniter,codeigniter php 7.1,codeigniter php 7.2,codeigniter centos 7,codeigniter php 7 session,codeigniter php 7.0,codeigniter php 7 mysql,codeigniter mpdf 7,codeigniter php 7.1 session,codeigniter php 7 error,php 7 codeigniter,mpdf 7 codeigniter,centos 7 codeigniter,php 7 codeigniter session,framework 7 codeigniter,centos 7 codeigniter remove index.php,nusoap php 7 codeigniter,codeigniter 7,mpdf 7 codeigniter 3,codeigniter 8192,codeigniter port 8080,codeigniter utf 8,codeigniter netbeans 8,codeigniter utf 8 encode,codeigniter netbeans 8.2,codeigniter netbeans 8 plugin,codeigniter netbeans 8.1 plugin,codeigniter iis 8,utf 8 codeigniter,netbeans 8 codeigniter,charset utf-8 codeigniter,codeigniter cloud 9,codeigniter debian 9,cloud 9 codeigniter,codeigniter,codeigniter adalah,codeigniter download,codeigniter upload,codeigniter 4,codeigniter form validation,codeigniter vs laravel,codeigniter session,codeigniter crud,codeigniter tutorial,codeigniter adminlte,codeigniter adminlte crud,codeigniter ajax,codeigniter api,codeigniter admin,codeigniter auth,codeigniter admin template,codeigniter atau laravel,codeigniter anchor,codeigniter a href,codeigniter a database error occurred,codeigniter a php error was encountered,codeigniter a session had already been started - ignoring session_start(),codeigniter a non-numeric value encountered,codeigniter a non well formed numeric value encountered,codeigniter a php error was encountered severity 8192,codeigniter a href helper,codeigniter a php error was encountered severity notice message undefined variable,codeigniter a php error was encountered core/common.php,codeigniter bootstrap,codeigniter blog,codeigniter between,codeigniter base_url,codeigniter bootstrap dashboard template,codeigniter between date,codeigniter builder,codeigniter belajar,codeigniter breadcrumb,codeigniter bootstrap 4,codeigniter cms,codeigniter captcha,codeigniter composer,codeigniter cart,codeigniter codepolitan,codeigniter controller,codeigniter curl,codeigniter count,codeigniter datatables,codeigniter database,codeigniter delete,codeigniter datatables server side,codeigniter dompdf,codeigniter download file,codeigniter dropdown from database,codeigniter distinct,codeigniter d,yesi d codeigniter,codeigniter email,codeigniter encrypt,codeigniter ebook,codeigniter export pdf,codeigniter export excel,codeigniter example,codeigniter ecommerce,codeigniter excel,codeigniter error 500,codeigniter edit data,codeigniter e-commerce,bootstrap ke codeigniter,codeigniter e-learning,ebook codeigniter,codeigniter e-library,e commerce codeigniter download,e commerce dengan codeigniter,e commerce using codeigniter,e-learning dengan codeigniter,codeigniter e commerce application,codeigniter form,codeigniter framework,codeigniter file upload,codeigniter firebase,codeigniter flashdata,codeigniter forum,codeigniter form select,codeigniter foreach,codeigniter fpdf,codeigniter get,codeigniter github,codeigniter group by,codeigniter get_where,codeigniter generator,codeigniter guide,codeigniter get row,codeigniter get url,codeigniter get current url,codeigniter get session,codeigniter hmvc,codeigniter htaccess,codeigniter helper,codeigniter hotel

pemrograman web mata kuliah,pemrograman web materi,pemrograman web menggunakan php,pemrograman web majumapan,pemrograman web menggunakan html,pemrograman web notepad++,bahasa pemrograman web.net,pemrograman web dengan vb.net,pemrograman web online shop,pemrograman web oop,pemrograman web online,kursus pemrograman web online,pemrograman web toko online,operator pemrograman web,pemrograman web ppt,pemrograman web perangkat bergerak,pemrograman web python,pemrograman web php pdf,pemrograman web pengertian,pemrograman web perpustakaan,pemrograman web penjualan,pemrograman web php mysql,quiz pemrograman web,pemrograman web rpl,pemrograman web dengan ruby,bahasa pemrograman web ruby,rpp pemrograman web,rpp pemrograman web dinamis kurikulum 2013,rpp pemrograman web dinamis kelas xi smk rekayasa perangkat lunak,rpp pemrograman web dan perangkat bergerak,rps pemrograman web,rpp pemrograman web doc,pemrograman web statis,pemrograman web seperti apakah yang harus dipelajari anak didik di zaman yang sudah serba online,pemrograman web sederhana,pemrograman web smk kelas x,pemrograman web smk ppt,pemrograman web semester 2,pemrograman web semester 2 pdf,pemrograman web server,pemrograman web service,pemrograman web terbaru,pemrograman web terbaik,pemrograman web tkj,pemrograman web table,pemrograman web teori,pemrograman web tabel,pemrograman web unpas,pemrograman web untuk pemula,pemrograman web ub,pemrograman web uii,pemrograman web 2 unindra,laporan pemrograman web ub,pemrograman web 1 unindra,materi pemrograman web untuk smk,pemrograman web dengan visual basic,pemrograman web dengan visual studio,pemrograman desktop vs web,video pemrograman web,pemrograman web wikipedia,pemrograman web kelas x semester 1,pemrograman web dengan xampp,pemrograman web kelas x smk,materi kelas x pemrograman web,pemrograman web x,pemrograman web yang ditentukan pada sisi client adalah,pemrograman web yang paling mendasar adalah,pemrograman web yang ditentukan pada sisi client,pemrograman web yang diproses pada komputer client adalah,bahasa pemrograman web yang paling banyak digunakan,bahasa pemrograman web yang paling mudah,contoh pemrograman web yang menggunakan php dan mysql,pemrograman web 1 pdf,pemrograman web 1 html,pemrograman web kelas 10,pemrograman web kelas 10 semester 2,pemrograman web kelas 11,pemrograman web semester 1,sap pemrograman web 1,makalah pemrograman web 1,silabus pemrograman web 1,pemrograman web 2 pdf,pemrograman web 2 dengan php,pemrograman web 2017,pemrograman web 2 kelas x,makalah pemrograman web 2,bahasa pemrograman web 2017,pemrograman web semester 2 kelas x,2 jenis pemrograman web,2 kategori pemrograman web,3 bahasa pemrograman web,pemrograman web 3,4 bahasa pemrograman web,5 bahasa pemrograman web,sebutkan 5 bahasa pemrograman web,pemrograman web dengan php 7,pemrograman web dengan php 7 betha sidik,9-c2-pemrograman web-x-1.pdf,pemrograman web,pemrograman web adalah,pemrograman web dinamis,pemrograman web pdf,pemrograman web kelas x,pemrograman web dinamis pdf,pemrograman web dan mobile,pemrograman web dasar,pemrograman web atau desktop,pemrograman web array,pemrograman web asp.net,pemrograman aplikasi web,pemrograman berbasis web adalah,bahasa pemrograman web adalah,pemrograman web dinamis adalah,pemrograman web di android,pemrograman web itu apa,pemrograman web berbasis framework,pemrograman web berbasis php,pemrograman web berbasis objek,pemrograman web berorientasi objek,pemrograman web berbasis jsp,pemrograman web berbasis oop,pemrograman web base,pemrograman web berbasis server,pemrograman web buku,pemrograman web css,pemrograman web ci,pemrograman web crud,pemrograman web client side,pemrograman web client,pemrograman web coding,teknik pemrograman web client,soal pemrograman web css,materi pemrograman web css,modul pemrograman web css,pemrograman web dengan php dan mysql,pemrograman web enterprise,pemrograman web ebook,pemrograman web enterprise adalah,soal pemrograman web essay,modul pemrograman web enterprise,ebook pemrograman web dinamis menggunakan php dan mysql,ebook pemrograman web dengan php dan mysql pdf,editor pemrograman web,ebook pemrograman web html,konsep pemrograman web dan enterprise,ebook pemrograman web,pemrograman web framework,pemrograman web formulir pendaftaran,pemrograman web frame,laporan pemrograman web filkom ub,pemrograman web membuat form,materi pemrograman framework web,fungsi pemrograman web,forum pemrograman web,pemrograman web gratis,pemrograman web gunadarma,pemrograman web gis,buku pemrograman web gratis,ebook pemrograman web gratis,belajar pemrograman web gratis,download buku pemrograman web gratis,soal uas pemrograman web gunadarma,gambar pemrograman web,pemrograman web html lengkap,pemrograman web html dengan notepad,pemrograman web html.pdf,pemrograman web html ppt,soal pemrograman web html,materi pemrograman web html,modul pemrograman web html,belajar pemrograman web html,tugas pemrograman web html,pemrograman web ii,pemrograman web teknik informatika,materi pemrograman web i,istilah pemrograman web,pemrograman web java,pemrograman web javascript,pemrograman web java pdf,pemrograman java web dengan netbeans,kursus pemrograman web jogja kabupaten sleman daerah istimewa yogyakarta,kursus pemrograman web jakarta,pemrograman web dengan javascript,kursus pemrograman web jogja kabupaten sleman daerah istimewa yogyakarta 55283,modul pemrograman web java,pemrograman web kelas xi,pemrograman web kelas 10 semester 1,pemrograman web kelas x semester 2,pemrograman web kelas x semester 2 pdf,pemrograman web k13,pemrograman web lanjut,pemrograman web lanjutan,pemrograman web lengkap pdf,pemrograman web laravel,pemrograman web login,pemrograman web lengkap,materi pemrograman web lanjut,modul pemrograman web lengkap

Belajar PHP OOP Part 13 CRUD Dengan PDO



Halo! Sekarang sudah edisi ke 13, yeay! Dan di edisi Belajar PHP OOP kali ini, saya akan membahas tentang membuat aplikasi CRUD sederhana dengan PDO. Dan sudah pasti kita bakalan mengimplementasikan apa yang sudah dipelajari di edisi Belajar PHP OOP sebelumnya. Kalau sudah dengar CRUD (Create, Read, Update, Delete), pasti kamu bisa membayangkan aplikasi yang bisa memanipulasi data, seperti menambahkan, menampilkan, mengubah dan menghapus data. Kalau di postingan saya sebelumnya, kita sudah membahas tentang CRUD dengan framework CodeIgniter [Baca: CRUD Sederhana CodeIgniter]. Nah, untuk kali ini kita akan membahas CRUD PDO. Untuk yang belum kenal apa itu PDO, kita kenalan dulu, ya!

Jadi, PDO itu singkatan dari PHP Data Object. Nah, PDO ini tuh extension di PHP yang digunakan untuk mengakses database. Dalam PDO juga terdapat data-access abstraction layer pada PDO, sehingga memungkinkan kita menggunakan fungsi yang sama untuk berbagai jenis database. Mau pakai MySQL, MSSQL, Postgresql, ataupun Oracle, kamu bisa pakai fungsi yang sama untuk memanipulasi data.

Lalu, kenapa CRUD Dengan PDO jadi tema di edisi kali ini? Itu karena, beberapa waktu yang lalu, di diskusi grup ada yang menanyakan hal yang terkait Deprecated-nya MySQL sewaktu upgrade versi PHP, katanya terdapat error pada aplikasinya karena masih menggunakan MySQL. Setelah saya googling, banyak yang menyarankan untuk menggunakan PDO. (Sebetulnya dierrornya juga sudah ada petunjuknya sih, kalau kita perhatikan). Hmm, ini cukup menggelitik rasa penasaran saya untuk mencoba membuat aplikasi CRUD sederhana dengan PDO dan untuk tampilannya (user interface), saya akan coba memakai Bootsrap. Daan, sebagai contoh saya akan membuat aplikasi CRUD sederhana untuk mengelola data barang pada aplikasi kasir. Seperti apa langkah-langkah dalam membuat aplikasi CRUD dengan PDO? Try this out ya!

[1] Persiapan
Ya, pertama kita harus menyiapkan lab kita. Kita buat folder baru di dalam folder htdocs (asumsi, kamu pakai Xampp) kita kasih nama aplikasi_kasir. (kamu boleh kasih nama apa aja, bebas kok..) ^^
Nanti folder tersebut bakalan kita pakai untuk menyimpan file-file php. FYI, Karena User Interfacenya saya menggunakan Bootsrap yang diload melalui CDN, mungkin kamu perlu juga siapin koneksi internet. Atau kamu bisa download Bootstrapnya terlebih dahulu di tautan ini.

Selanjutnya kita akan buat database. Karena aplikasi yang akan kita buat itu berhubungan dengan manipulasi data atau CRUD, tentu saja kita harus buat database terlebih dahulu. Sekarang saya buat database menggunakan phpMyAdmin. Databasenya saya beri nama belajar_oop. Setelah itu kita buat table di dalam database yang baru saja kita buat, saya kasih nama barang dengan struktur tabel seperti gambar berikut:



Oh iya, kita juga bisa buat table pakai perintah SQL di bawah ini lho!

 CREATE TABLE `barang` (

`id_barang` varchar(10) NOT NULL,

`nama` varchar(50) NOT NULL,

`stok` int(10) NOT NULL,

`harga` int(25) NOT NULL,

PRIMARY KEY (`id_barang`)

) ENGINE=InnoDB DEFAULT CHARSET=latin1;



Kalau tabelnya sudah kamu buat, kamu boleh isi tabelnya sesuka hati. Sebagai contoh saya isi kaya gambar ini:



Abaikan harga barang yang sama, namanya juga contoh. Hihi

[2] Konfigurasi Database
Setelah database dan tabelnya sudah kita buat, selanjutnya kita buat file untuk mengkonfigurasi database. Buka text editor kesayanganmu, lalu ketik sintaks di bawah ini:

 <?php

try

{

$con = new PDO('mysql:host=localhost;dbname=belajar_oop', 'root', '', array(PDO::ATTR_PERSISTENT => true));

}

catch(PDOException $e)

{

echo $e->getMessage();

}

include_once 'barang_class.php';

$brg = new barang($con);

?>



Simpan filenya di folder aplikasi_kasir dengan nama dbconfig.php.

Bisa kita lihat, pada baris ke 5, kita akan membuat object $con menggunakan Class PDO, bersamaan dengan informasi data source name dan user credential pada parameternya, yaitu localhost untuk hostnya, belajar_oop untuk databasenya, root untuk username dan password (isi password kalau mysql kamu pakai password).

Selain konfigurasi database, kita juga akan memanggil file barang_class.php menggunakan fungsi include_once pada baris ke 12. Lalu kita buat sebuah object dengan $brg. Nanti kita bakalan pakai object ini di file lainnya.

[3] Coding Time
Ya, it's coding time! Langkah selanjutnya kita akan membuat beberapa file php, yaitu barang_class.php, index.php, add.php, edit.php, dan hapus.php. File-file php tersebut dan file dbconfig.php kita simpan dalam folder aplikasi_kasir. Sekarang kita buat file barang_class.php. Buka kembali text kesayanganmu, lalu ketik sintaks di bawah ini:

 <?php

class barang

{

private $db;

public function __construct($con){

$this->db = $con;

}

### Start : fungsi insert data ke database ###

public function insertData($id_barang,$nama,$stok,$harga){

try{

$stmt = $this->db->prepare("INSERT INTO barang(id_barang,nama,stok,harga) VALUES(:id_barang, :nama, :stok, :harga)");

$stmt->bindparam(":id_barang",$id_barang);

$stmt->bindparam(":nama",$nama);

$stmt->bindparam(":stok",$stok);

$stmt->bindparam(":harga",$harga);

$stmt->execute();

return true;

}catch(PDOException $e){

echo $e->getMessage();

return false;

}

}

### End : fungsi insert data ke database ###

### Start : fungsi ambil data dari database ###

public function getID($id_barang){

$stmt = $this->db->prepare("SELECT * FROM barang WHERE id_barang=:id_barang");

$stmt->execute(array(":id_barang"=>$id_barang));

$data=$stmt->fetch(PDO::FETCH_ASSOC);

return $data;

}

### End: fungsi ambil data dari database ###

### Start : fungsi untuk menampilkan data dari database ###

public function viewData($query){

$stmt = $this->db->prepare($query);

$stmt->execute();

if($stmt->rowCount()>0){

while($row=$stmt->fetch(PDO::FETCH_ASSOC)){

?>

<tr>

<td><?php echo($row['id_barang']); ?></td>

<td><?php echo($row['nama']); ?></td>

<td><?php echo($row['stok']); ?></td>

<td><?php echo($row['harga']); ?></td>

<td align="center">

<a href="edit.php?edit_id=<?php echo($row['id_barang']); ?>">

<i class="glyphicon glyphicon-edit"></i></a>

</td>

<td align="center">

<a href="hapus.php?delete_id=<?php echo($row['id_barang']); ?>">

<i class="glyphicon glyphicon-remove-circle"></i></a>

</td>

</tr>

<?php

}

}else{

?>

<tr>

<td>Data tidak ditemukan...</td>

</tr>

<?php

}

}

### End : fungsi untuk menampilkan data dari database ###

### Start : fungsi untuk memperbaharui data###

public function updateData($id_barang,$nama,$stok,$harga){

try{

$stmt=$this->db->prepare("UPDATE barang SET nama=:nama,

stok=:stok,

harga=:harga

WHERE id_barang=:id_barang ");

$stmt->bindparam(":id_barang",$id_barang);

$stmt->bindparam(":nama",$nama);

$stmt->bindparam(":stok",$stok);

$stmt->bindparam(":harga",$harga);

$stmt->execute();

return true;

}catch(PDOException $e){

echo $e->getMessage();

return false;

}

}

### End : fungsi untuk memperbaharui data###

### Start : fungsi untuk menghapus data###

public function deleteData($id_barang){

$stmt = $this->db->prepare("DELETE FROM barang WHERE id_barang=:id_barang");

$stmt->bindparam(":id_barang",$id_barang);

$stmt->execute();

return true;

}

### End : fungsi untuk menghapus data###

### Start : fungsi paging###

public function paging($query,$records_per_page){

$starting_position=0;

if(isset($_GET["page_no"])){

$starting_position=($_GET["page_no"]-1)*$records_per_page;

}

$query2=$query." limit $starting_position,$records_per_page";

return $query2;

}

### End : fungsi paging###

### Start : fungsi pindah page###

public function paginglink($query,$records_per_page){

$self = $_SERVER['PHP_SELF'];

$stmt = $this->db->prepare($query);

$stmt->execute();

$total_no_of_records = $stmt->rowCount();

if($total_no_of_records > 0){

?><ul class="pagination"><?php

$total_no_of_pages=ceil($total_no_of_records/$records_per_page);

$current_page=1;

if(isset($_GET["page_no"])){

$current_page=$_GET["page_no"];

}

if($current_page!=1){

$previous =$current_page-1;

echo "<li><a href='".$self."?page_no=1'>First</a></li>";

echo "<li><a href='".$self."?page_no=".$previous."'>Previous</a></li>";

}

for($i=1;$i<=$total_no_of_pages;$i++){

if($i==$current_page){

echo "<li><a href='".$self."?page_no=".$i."' style='color:red;'>".$i."</a></li>";

}else{

echo "<li><a href='".$self."?page_no=".$i."'>".$i."</a></li>";

}

}

if($current_page!=$total_no_of_pages){

$next=$current_page+1;

echo "<li><a href='".$self."?page_no=".$next."'>Next</a></li>";

echo "<li><a href='".$self."?page_no=".$total_no_of_pages."'>Last</a></li>";

}

?></ul><?php

}

}

### End : fungsi pindah page###

}



Simpan kembali file barang_class.php.

Selanjutnya, kita buat file index.php yang digunakan untuk menampilkan data barang dalam tabel. Buka kembali teks editor lalu ketik sintaks di bawah ini:

 <?php

include_once 'dbconfig.php';

?>

<!DOCTYPE html>

<html lang="en">

<head>

<title>Aplikasi CRUD Sederhana Dengan PHP OOP PDO</title>

<meta charset="utf-8">

<meta name="viewport" content="width=device-width, initial-scale=1">

<!--Bootstrap-->

<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">

</head>

<body>

<div class="container">

<div class="panel panel-primary">

<div class="panel-heading">Data Barang</div>

<div class="panel-body">

<a href="add.php" class="btn btn-large btn-default">

<i class="glyphicon glyphicon-plus"></i>

&nbsp; Tambah Data</a>

<br/><br/>

<table class='table table-bordered table-responsive'>

<tr>

<th>ID Barang</th>

<th>Nama Barang</th>

<th>Stok</th>

<th>Harga</th>

<th colspan="2" align="center">Actions</th>

</tr>

<?php

$query = "SELECT * FROM barang";

$records_per_page=5;

$newquery = $brg->paging($query,$records_per_page);

$brg->viewData($newquery);

?>

<tr>

<td colspan="7" align="center">

<div class="pagination-wrap">

<?php $brg->paginglink($query,$records_per_page); ?>

</div>

</td>

</tr>

</table>

</div><!--End: Panel-body-->

</div><!--End: Panel-->

</div>

<div class="container">

<div class="alert alert-success">

<p><strong>Selamat Belajar :) </strong></p>

<p>If you have question, feel free to ask me <a href="http://facebook.com/gungunpriatna002">here</a>!</p>

</div>

</div>

<!--Bootstrap-->

<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>

</body>

</html>



Simpan kembali file index.php.

Nah, untuk menambahkan data kita akan buat file add.php. Ketik lagi sintaks di bawah ini ya! ^^

 <?php

include_once 'dbconfig.php';

if(isset($_POST['btn-save']))

{

$id_barang = strtoupper($_POST['id_barang']);

$nama = $_POST['nama'];

$stok = $_POST['stok'];

$harga = $_POST['harga'];

if($brg->insertData($id_barang,$nama,$stok,$harga)){

header("Location: add.php?inserted");

}else{

header("Location: add.php?failure");

}

}

?>

<!DOCTYPE html>

<html lang="en">

<head>

<title>Aplikasi CRUD Sederhana Dengan PHP OOP PDO</title>

<meta charset="utf-8">

<meta name="viewport" content="width=device-width, initial-scale=1">

<!--Bootstrap-->

<!--Bootstrap-->

<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">

</head>

<body>

<div class="container">

<div class="panel panel-primary">

<div class="panel-heading">Form Tambah Data</div>

<div class="panel-body">

<?php

if(isset($_GET['inserted']))

{

?>

<div class="container">

<div class="alert alert-info">

<strong>Info!</strong> Data berhasil tersimpan! Silakan klik di <a href="index.php">sini</a> untuk kembali ke beranda.

</div>

</div>

<?php

}

else if(isset($_GET['failure']))

{

?>

<div class="container">

<div class="alert alert-warning">

<strong>Warning!</strong> Data gagal disimpan !

</div>

</div>

<?php

}

?>

<div class="clearfix"></div><br />

<form method='post'>

<table class='table table-bordered'>

<tr>

<td>Id Barang</td>

<td><input type='text' name='id_barang' class='form-control' required maxlength="10" autofocus></td>

</tr>

<tr>

<td>Nama Barang</td>

<td><input type='text' name='nama' class='form-control' required maxlength="50"></td>

</tr>

<tr>

<td>Stok</td>

<td><input type='text' name='stok' class='form-control' required></td>

</tr>

<tr>

<td>Harga</td>

<td><input type='text' name='harga' class='form-control' required></td>

</tr>

<tr>

<td colspan="2">

<button type="submit" class="btn btn-primary" name="btn-save">Simpan

</button>

<button type="reset" class="btn btn-primary" name="btn-reset">Reset

</button> <br/><br/>

<a href="index.php" class="btn btn-large btn-success">

<i class="glyphicon glyphicon-backward"></i> &nbsp; Kembali ke halaman utama</a>

</td>

</tr>

</table>

</form>

</div><!--End: Panel-body-->

</div><!--End: Panel-->

</div>

<div class="container">

<div class="alert alert-success">

<p><strong>Selamat Belajar :) </strong></p>

<p>If you have question, feel free to ask me <a href="http://facebook.com/gungunpriatna002">here</a>!</p>

</div>

</div>

<!--Bootstrap-->

<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>

</body>

</html>



Setelah selesai diketik, simpan kembali file add.php.

Berikutnya, kita buat file edit.php. Ya, buka kembali text editor kesayanganmu, lalu ketik sintaks di bawah ini:

 <?php

include_once 'dbconfig.php';

$id_barang = $_GET['edit_id'];

if(isset($_POST['btn-update'])){

$nama = $_POST['nama'];

$stok = $_POST['stok'];

$harga = $_POST['harga'];

if($brg->updateData($id_barang,$nama,$stok,$harga)){

$msg = "<div class='alert alert-info'>

<strong>Info</strong> Data berhasil diubah! Silakan klik di <a href='index.php'>sini</a> untuk kembali ke beranda.

</div>";

}else{

$msg = "<div class='alert alert-warning'>

<strong>Warning!</strong> Update Data Gagal !

</div>";

}

}

if(isset($id_barang)){

extract($brg->getID($id_barang));

}

?>

<!DOCTYPE html>

<html lang="en">

<head>

<title>Aplikasi CRUD Sederhana Dengan PHP OOP PDO</title>

<meta charset="utf-8">

<meta name="viewport" content="width=device-width, initial-scale=1">

<!--Bootstrap-->

<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">

</head>

<body>

<div class="container">

<div class="panel panel-primary">

<div class="panel-heading">Form Edit Data</div>

<div class="panel-body">

<?php

if(isset($msg))

{

echo $msg;

}

?>

</div>

<div class="clearfix"></div><br />

<form method='post'>

<table class='table table-bordered'>

<tr>

<td>Id Barang</td>

<td><input type='text' name='id_barang' class='form-control' required maxlength="10" value="<?php echo $id_barang; ?>" readonly></td>

</tr>

<tr>

<td>Nama Barang</td>

<td><input type='text' name='nama' class='form-control' required maxlength="50" value="<?php echo $nama; ?>" autofocus></td>

</tr>

<tr>

<td>Stok</td>

<td><input type='text' name='stok' class='form-control' value="<?php echo $stok; ?>" required></td>

</tr>

<tr>

<td>Harga</td>

<td><input type='text' name='harga' class='form-control' value="<?php echo $harga; ?>" required></td>

</tr>

<tr>

<td colspan="2">

<button type="submit" class="btn btn-primary" name="btn-update">Simpan

</button>

<button type="reset" class="btn btn-primary" name="btn-reset">Reset

</button> <br/><br/>

<a href="index.php" class="btn btn-large btn-success">

<i class="glyphicon glyphicon-backward"></i> &nbsp; Kembali ke halaman utama</a>

</td>

</tr>

</table>

</form>

</div><!--End: Panel-body-->

</div><!--End: Panel-->

</div>

<div class="container">

<div class="alert alert-success">

<p><strong>Selamat Belajar :) </strong></p>

<p>If you have question, feel free to ask me <a href="http://facebook.com/gungunpriatna002">here</a>!</p>

</div>

</div>

<!--Bootstrap-->

<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>

</body>

</html>



Yep, simpan file edit.php.

Dan yang terakhir, kita buat file hapus.php. Ok, ketik kembali sintaks di bawah ini:

 <?php

include_once 'dbconfig.php';

if(isset($_POST['btn-del'])){

$id_barang = $_GET['delete_id'];

$brg->deleteData($id_barang);

header("Location: hapus.php?deleted");

}

?>

<!DOCTYPE html>

<html lang="en">

<head>

<title>Contoh Implementasi Class Diagram</title>

<meta charset="utf-8">

<meta name="viewport" content="width=device-width, initial-scale=1">

<!--Bootstrap-->

<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">

</head>

<body>

<div class="container">

<div class="panel panel-primary">

<div class="panel-heading">Halaman Hapus Data</div>

<div class="panel-body">

<?php

if(isset($_GET['deleted']))

{

?>

<div class="alert alert-success">

<strong>Info!</strong> Data berhasil dihapus...

</div>

<?php

}

else

{

?>

<div class="alert alert-danger">

<strong>Warning!</strong> apa anda yakin ingin menghapusnya ?

</div>

<?php

}

?>

</div>

<div class="container">

<?php

if(isset($_GET['delete_id'])){

$id_barang = $_GET['delete_id'];

?>

<table class='table table-bordered'>

<tr>

<th>#</th>

<th>Nama</th>

<th>Stok</th>

<th>Harga</th>

</tr>

<?php

extract($brg->getID($id_barang));

?>

<tr>

<td><?php echo $id_barang; ?></td>

<td><?php echo $nama; ?></td>

<td><?php echo $stok; ?></td>

<td><?php echo $harga; ?></td>

</tr>

</table>

<?php

}

?>

</div>

<div class="container">

<p>

<?php

if(isset($id_barang))

{

?>

<form method="post">

<input type="hidden" name="id" value="<?php echo $id_barang; ?>" />

<button class="btn btn-large btn-primary" type="submit" name="btn-del">

<i class="glyphicon glyphicon-trash"></i> &nbsp; YES</button>

<a href="index.php" class="btn btn-large btn-success">

<i class="glyphicon glyphicon-backward"></i> &nbsp; NO</a>

</form>

<?php

}

else

{

?>

<a href="index.php" class="btn btn-large btn-success">

<i class="glyphicon glyphicon-backward"></i> &nbsp; Back to index</a>

<?php

}

?>

</p>

</div>

</div><!--End: Panel-body-->

</div><!--End: Panel-->

</div>

<div class="container">

<div class="alert alert-success">

<p><strong>Selamat Belajar :) </strong></p>

<p>If you have question, feel free to ask me <a href="http://facebook.com/gungunpriatna002">here</a>!</p>

</div>

</div>

<!--Bootstrap-->

<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>

</body>

</html>



Simpan file hapus.php dan selesai. :D
Nah, sekarang kita punya 6 file php yang di simpan di folder aplikasi_kasir. Bisa kita lihat di gambar di bawah ini.



[4] Uji Coba Program
Nah, sekarang kita coba run di browser, nanti bakalan muncul tampilan seperti di gambar ini:



Yep, di gambar di atas sudah ada datanya, soalnya tadi sudah saya isi sewaktu buat table. Hihi. Nah, untuk menambah data barang, coba klik tombol 'Tambah Data', nanti bakalan dialihkan ke halaman add.php. Di halaman ini ada form untuk menambah data barang. Sekarang kita coba isi formnya, misalnya kaya gini.. ^^



Setelah kamu isi formnya, klik tombol 'Simpan' untuk menyimpan data barang. Nah, untuk mengecek datanya udah disimpan atau belum kamu bisa klik tombol 'Kembali ke halaman utama'. Nah, kamu bisa lihat datanya udah tersimpan.



Di gambar di atas, saya udah coba menambah beberapa barang. Kalau data melebihi 5, nanti bakalan nambah halamannya kaya gambar di atas. Untuk mengatur jumlah data yang ditampilkan di dalam tabel, cek halaman index.php line 35.



Di line 35 ada variabel $records_per_page, valuenya disetting 5 untuk menampilkan 5 data perhalamannya. Untuk mengatur data yang ditampilkan perhalamannya, kamu bisa mengganti value variabel tersebut.

Selanjutnya, coba kamu perhatikan di tabel ada kolom 'Actions' yang berisi dua icon, icon edit sama icon delete. Nah, untuk mengedit data barang, coba kamu klik icon edit.



Kamu bisa lihat form edit dan juga data barangnya. Coba kamu edit datanya, lalu klik 'Simpan'. Bakalan muncul pemberitahuan kalau data berhasil diubah. Sekarang klik tombol ke 'Kembali ke halaman utama', kita bisa lihat di tabel kalau datanya sudah berhasil kita ubah. ^^





Lalu, bagaimana kalau kita mau hapus data barang? Yep, kamu benar.^^ Kita tinggal klik icon 'delete' di kolom actions. Nanti bakalan muncul pertanyaan untuk konfirmasi hapus data. Kamu tinggal Klik 'Yes' untuk menghapus data.


See? Datanya sudah terhapus.. ^^

****

Kawan, aplikasi CRUD ini masih sederhana. Masih banyak kekurangan yang bisa diperbaiki. Masih terdapat banyak ruang yang bisa kamu kembangkan. Semoga dengan adanya seri Belajar PHP OOP edisi ke 13 ini bisa menambah semangat belajarmu, yes!

Semoga bermanfaat.. ^^


***
Referensi:
Situs utama PHP @ http://www.php.net;
Manual PHP @ http://php.net/manual/en/index.php;
PDO @ http://php.net/manual/en/book.pdo.php 

Belajar PHP OOP Part 13 CRUD Dengan PDO Rating: 4.5 Diposkan Oleh: Kabar Viral

Categories

Popular Posts