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

Do It With SQL

Beberapa hari yang lalu, saya mengikuti salah satu program dari komunitas PHP Indonesia, yaitu PHP Indonesia For Student. Banyak manfaat yang bisa saya dapatkan semenjak mengikuti program ini. Ya, salah satunya adalah mendapatkan ilmu melalui kuliah telegram. Kuliah telegram ini bisa diikuti setiap hari lho! Dan tiap hari akan membahas tema yang berbeda-beda.  Dan tema kuliah telegram kemarin mengusung tema #DoItWithSQL. Dan sudah pasti materi yang dibahas di perkuliahan kali ini adalah SQL. Salah satu skill yang sangat penting untuk seorang developer. Ya, postingan kali ini adalah hasil dari kuliah telegram #DoItWithSQL kemarin. Ok, kita mulai!



Ya, seperti yang sudah disebutkan sebelumnya, tema kuliah telegram ini adalah #DoItWithSQL. Dan pemateri keren yang sudah meluangkan waktu di tengah kesibukannya untuk menyampakan materi adalah Om Nur Hidayat. Beliau adalah seorang developer di PT Cronos Studio Indonesia. Dan berikut ini adalah rangkuman Kuliah Telegram #DoItWithSQL.

***

Sebagai seorang developer harus tahu semua teknologi, walaupun sedikit, namun tetaplah punya satu atau dua spesialisasi tertentu. Salah satunya adalah skill SQL. Pemahaman yang baik tentang structured query language (SQL) menjadi hal yang amat sangat penting karena SQL adalah bahasa yang kita gunakan untuk berkomunikasi dengan database.

Sayangnya kenyataan berkata lain, peningkatan skill SQL menjadi prioritas paling akhir karena kebanyakan programmer terlalu fokus pada hal lain yang lebih seksi, seperti:
- meningkatkan skill bahasa pemrograman tertentu,
- membuat user interface yang atraktif dan user-friendly,
- membuat aplikasi yang bisa berjalan di database apapun

Akibatnya muncul kelucuan-kelucuan seperti berikut ini:

#Kelucuan Pertama, kebanyakan programmer menjadi kurang piawai meracik SQL. Pengetahuan tentang SQL statement hanya sebatas perintah SELECT, INSERT, UPDATE, dan DELETE sederhana saja tanpa memanfaatkan JOIN. Sehingga SQL statement yang dibuat terkesan asal jadi.

#Kelucuan Kedua, kebanyakan programmer tidak memanfaatkan kemampuan canggih yang dimiliki database engine yang digunakan. Sebagai contoh adalah hanya memanfaatkan database sebagai data store saja, dan proses pengolahan data seluruhnya dilakukan di level aplikasi. Padahal seharusnya pemrosesan data bisa diserahkan ke database dengan memanfaatkan aggregate functions, analytical/windowing functions, dan stored procedures.

#Kelucuan Ketiga, membawa gaya pemrograman prosedural saat memproses data. sebagai contoh untuk memproses data besar masih menggunakan looping (perulangan) di level aplikasi, akibatnya kinerja aplikasi semakin menurut seiring dengan bertambah banyaknya data. Padahal seharusnya saat kita memproses data di database harus menggunakan paradigma berpikir set (himpunan) dan bulk processing, bukan cara prosedural.

Untuk mengatasi semua #kelucuan di atas, kita sebagai developer harus paham perintah SQL luar dalem 😊. Untuk itu kita perlu membedah isi perintah SQL untuk memahami anatomi-nya.

[1] Anatomi SQL





Perintah SQL memiliki struktur dasar yang harus kita pahami agar kita bisa membuat sebuat perintah SQL yang baik dan benar. Perintah SQL terdiri dari beberapa bagian. Terminologi berikut ini tidak perlu dihapal tapi harus diketahui dan dipahami, yaitu:

[a] Statement, atau biasa disebut sebagai query, adalah keseluruhan perintah itu sendiri.

[b] Clause, adalah potongan perintah yang diawali kata kunci SQL tertentu, seperti....
- SELECT cluase,
- SET clause,
- UPDATE clause,
- WHERE clause,
- JOIN clause
dan sebagainya.

[c] Predicate, adalah sebuah kalimat matematika berupa perbandingan antara sebuah field dengan field lain, atau perbandingan antara sebuah field dengan nilai tertentu.

[d] Expression, adalah sebuah kalimat matematika yang menghasilkan sebuah nilai tertentu, atau sebuah konstanta nilai tertentu, misalkan string 'OK', atau NOW()+10.

Jika sama2 kita bedah perintah ini
---------
SELECT emp_code, emp_name
FROM employees
WHERE salary >= 3000000

Ini adalah SELECT clause,
---------
SELECT emp_code, emp_name

Ini adalah FORM clause,
---------
FROM employees

Ini adalah WHERE clause
---------
WHERE salary >= 3000000

Ini adalah predicate
---------
salary >= 3000000

Dan ini adalah expression
---------
3000000


Variasi paling banyak dan akan sering kita gunakan adalah perintah SQL SELECT, karena perintah SQL SELECT ini akan sangat membantu kita dalam membuat sebuah report yang paling rumit sekalipun.



Dalam sebuah SQL SELECT, setiap clause memiliki fungsinya sendiri sendiri..... kita ketahui bahwa konsep RDBMS menyimpan data dalam bentuk baris dan kolom. Jika tabel di database kita representasikan seperti kotak di gambar di atas, maka FROM clause menentukan "kotak" mana yang ingin kita baca.

[a] SELECT clause menentukan kolom mana yang kita ambil datanya, di gambar direpresentasikan kolom berwarna merah.

[b] WHERE clause menentukan baris mana yang ingin kita ambil datanya..... peratikan pada gambar di atas direpresentasikan sebagai baris berwarna biru.

[c] Dan jika kita menggabungkan ketika clause tersebut SELECT ... FROM ... WHERE .... maka kita akan mendapatkan data yang berwarna hijau.

Jadi.... hati-hati ketika kita menjalankan perintah:
UPDATE mytable
SET mycolumn = NULL

.......... tanpa WHERE clause, maka akibatnya adalah semua row di tabel bersangkutan akan diubah
.......... coba bayangkan jika yang dijalankan adalah perintah DELETE tanpa WHERE clause.. lenyaplah semua data. 😅

OK..... sampai di sini masih bisa dipahami ya?
Kita akan lanjut ke topik berikutnya kalau gak ada pertanyaan atau komentar tentang #AnatomiSQL

[2] Join




Kadang-kadang ada yang bertanya apa bedanya antara JOIN dengan UNION dan kapan menggunakannya?

Jika kita mempunyai dua buah table, satu berwarna biru, dan satu lagi berwarna merah, maka...... JOIN akan menghasilkan table baru dengan kolom yang merupakan gabungan dari kedua tabel tersebut, jadi yang bertambah adalah kolom-nya. Sedangkan UNION justru menambahkan baris row, menggabungkan isi kedua tabel tersebut, dengan syarat jumlah kolom harus sama dan tipe datanya juga harus sama.

UNION biasanya digunakan untuk menggabungkan beberapa tabel untuk dibuatkan sebuah laporan tertentu, contoh paling simple adalah jika kita membuat aplikasi inventory, kemudian menyimpan transaksi barang masuk dan transaksi barang keluar ke dalam dua tabel yang berbeda, maka UNION jadi solusi saat kita perlu membuat laporan kartu stok.

Lalu apa bedanya UNION dengan UNION ALL. Bedanya adalah UNION memastikan tidak ada row yang duplikat, sedangkan UNION ALL memperbolehkan adanya row duplikat.

Pada saat proses UNION, RDBMS memastikan tidak ada row yang duplikat dengan cara mengurutkan result set, dan satu-persatu menghapus row duplikat dari result set. Jadi..... ketika kita sudah yakin, haqqul yakin, bahwa tidak ada data duplikat dalam dua buah table yang ingin kita gabungkan, maka gunakan saja UNION ALL.... secara performance akan lebih baik karena RDBMS tidak perlu melakukan sorting untuk menghapus row duplikat.

[3] Variasi SQL Join




Ini pengkategorian dari saya saja, ada 4 variasi Standard JOIN:
- INNER JOIN (JOIN)
- LEFT OUTER JOIN (LEFT JOIN)
- RIGHT OUTER JOIN (RIGHT JOIN)
- FULL OUTER JOIN (FULL JOIN)
]
Dan Ada 3 macam variasi Advanced JOIN:
- LEFT EXCLUDING JOIN  (LEFT JOIN exclude INNER JOIN)
- RIGHT EXCLUDING JOIN  (RIGHT JOIN exclude INNER JOIN)
- FULL EXCLUDING JOIN (FULL JOIN exclude INNER JOIN)

Khusus MySQL (dan MariaDB), sampai saat ini belum support FULL JOIN.

Seperti yang sudah disebutkan dalam Intro, bahwa paradigma berpikir di database adalah "set" atau himpunan, maka representasi paling pas untuk menggambarkan proses JOIN antar tabel adalah dengan menggunakan diagram venn yang dulu kita pelajadi waktu masih imut-imut.



[*] INNER JOIN adalah query yang paling sederhana, paling umum, dan paling mudah dipahami. Query ini akan mengembalikan semua record dalam tabel kiri (tabel A) yang memiliki record yang cocok di tabel kanan (tabel B).



[*] Query LEFT JOIN akan mengembalikan semua record dalam tabel kiri (tabel A) meskipun record di tabel A tersebut tidak memiliki record yang bersesuaian di tabel kanan (tabel B). Dan semua record yang bersesuaian dari tabel kanan akan muncul.


[*] Query RIGHT JOIN akan mengembalikan semua record dalam tabel kanan (tabel B) meskipun record di tabel B tersebut tidak memiliki record yang bersesuaian di tabel kiri (tabel A). Semua record yang bersesuaian dari tabel kanan akan muncul.



[*] Query FULL JOIN akan mengembalikan semua record yang ada di kedua table tersebut, dan semua record yang bersesuaian akan digabungkan menjadi satu record.

Lalu bagaimana penggunaannya, kapan kita pakai INNER JOIN, LEFT JOIN, RIGHT JOIN, atau FULL JOIN?

[*] Kasus yang bisa diselesaikan dengan INNER JOIN misalnya "tampilkan semua mahasiswi yang mengambil kuliah di semester ini".

[*] Kasus yang bisa diselesaikan dengan LEFT JOIN misalnya "tampilkan semua mahasiswi yang mengambil kuliah di semester ini, termasuk mahasiswi yang cuti di semester ini".

[*] Kasus yang bisa diselesaikan dengan RIGHT JOIN misalnya "tampilkan semua mata kuliah yang diambil mahasiswi di semester ini, termasuk mata kuliah yang tidak laku".

[*] Kasus yang bisa diselesaikan dengan FULL JOIN misalnya "tampilkan semua mahasiswi yang mengambil kuliah di semester ini, termasuk mahasiswi yang cuti dan mata kuliah yang tidak laku".

Untuk sintaks masing2 JOIN bisa dipelajari [di artikel ini].

Lalu ada yang bertanya, "beda FULL JOIN dengan INNER JOIN dimananya yak? Lalu, bolehkah hanya menggunakan JOIN saja? Tanpa ada embel-embel INNER?".

Lengkapnya:
INNER JOIN bisa disingkat JOIN.
LEFT OUTER JOIN bisa disingkat LEFT JOIN.
RIGHT OUTER JOIN bisa disingkat RIGHT JOIN.
FULL OUTER JOIN bisa disingkat FULL JOIN.

Mengenai sintaks detil dan contohnya bisa dilihat di link yang saya berikan di atas.

...

Mudah-mudahan materi di atas tidak menjemukan.... karena kita akan masuk ke topik yang makin mendorong... eh... menarik.

Lalu ada yang bertanya lagi. Kalau yang sudah dibaca di link yang sudah disebutkan sebelumya, dibagian INNER JOIN dijelaskan bahwa:
INNER JOIN
Query ini akan mengembalikan semua record dalam tabel kiri (tabel A) yang memiliki record yang cocok di tabel kanan (tabel B)
FULL JOIN
mengembalikan semua record yang ada di kedua table tersebut, dan semua record yang bersesuaian akan digabungkan menjadi satu record.

Inner join itu nampilin isi tabel A yang bersesuaian dengan tabel B.
Sedangkan full join nampilin semua tabel A digabung dengan semua tabel B.

...

[4] Rule Of Thumb




RuleOfThumb From Tom Kyte, Oracle Database Evangelist:
1. Use single SQL statement whenever possible
2. Use PL/SQL or Stored Procedure
3. Use Java (or other programming language)
4. Rethink why you want to do it (refine your approach)

Terjemahan bebasnya:
1. Sebisa mungkin gunakan satu perintah SQL
2. Jika gak bisa, gunakanlah stored procedure
3. Jika masih gak bisa, gunakan bahasa Java (atau PHP)
4. Jika masih gak bisa juga, berarti ada yang salah nih


Lalu, seperti apa contoh penggunaan #RuleOfThumb? Di kuliah telegram kali ini om Nur memberikan tantangan, yaitu: Gunakan #RuleOfThumb Tampilkan angka 1 sampai dengan 100, namun setiap kelipatan 3 ubah angkanya menjadi kata "Rumah", setiap kelipatan 5 ubah angkanya menjadi kata "Sakit", dan setiap kelipatan 15 ubah angkanya menjadi kata "Rumah Sakit".

Dan setelah diskusi yang sangat menarik, inilah solusi dengan menggunakan #MySQL:


select case

 when baris mod 15 = 0 then 'Rumah Sakit'

 when baris mod 3  = 0 then 'Rumah'

 when baris mod 5  = 0 then 'Sakit'

 else baris end hasil

from (

 select @row := @row+1 baris

 from information_schema.columns

 join ( select @row := 0 ) rx

 limit 100

) tx



Subquery tx



 select @row := @row+1 baris

 from information_schema.columns

 join ( select @row := 0 ) rx

 limit 100


Digunakan untuk men-generate table berisikan angka 1 sampai 100.


Dan ini adalah solusi dengan menggunakan #PosgreSQL :


select case

 when baris %15 = 0 then 'Rumah Sakit'

 when baris %3  = 0 then 'Rumah'

 when baris %5  = 0 then 'Sakit'

 else to_char(baris,'999') end hasil

from (

  select generate_series(1,100) baris

) tx

Perhatikan bahwa di postgres ada fungsi khusus untuk men-generate angka yang kita inginkan, sehingga query jauh lebih simple.

***

Gimana? Menarik bukan? Sebagai seorang developer, kita memang harus tahu semua teknologi. Walaupun sedikit, namun tetaplah kita harus memiliki satu atau dua spesialisasi tertentu. Salah satunya adalah skill SQL. Pemahaman yang baik tentang structured query language (SQL) menjadi hal yang amat sangat penting karena SQL adalah bahasa yang kita gunakan untuk berkomunikasi dengan database. Dengan memahami SQL, kita dapat mengurangi kelucuan-kelucuan saat berinteraksi dengan database dan membuat program yang lebih baik lagi.

Semoga bermanfaat. Semoga belajarnya semakin menyenangkan... ^^

Do It With SQL Rating: 4.5 Diposkan Oleh: Kabar Viral

Categories

Popular Posts