Tutorial Php Mysql
December 14, 2017 | Author: ChiRagirl CwEet | Category: N/A
Short Description
Download Tutorial Php Mysql...
Description
PHP Web Development 9 Instalasi dan pengenalan PHP 9 SQL dengan menggunakan MySQL Server 9 PHP Scripting 9 Array dan String Functions 9 Integrasi PHP dan MySQL 9 Session dan Cookies 9 Handling File Uploads 9 Shopping Cart
PHP Web Development
Page 1 of 60
Daftar Isi Bagian 1 - Instalasi dan Pengenalan PHP ........................................................................................... 4 1.1 Instalasi PHP........................................................................................................ 4 1.2 Instalasi Apache Server 1.3.33 .............................................................................. 4 1.3 Instalasi MySQL Server ....................................................................................... 10 1.4 PHP Language Fundamental................................................................................ 10 1.4.1 HTML Tags .................................................................................................... 11 1.4.2 Variabel dalam PHP ........................................................................................ 18 1.4.3 Control Structure ............................................................................................ 18 1.4.4 Including PHP script........................................................................................ 19 Bagian 2 – Language Fundamental (Lanjutan).................................................................................... 21 2.1 Function ............................................................................................................ 21 2.2 Array................................................................................................................. 22 2.3 Array Functions .................................................................................................. 23 2.3.1 count ............................................................................................................ 23 2.3.2 array_keys ..................................................................................................... 23 2.3.3 array_values .................................................................................................. 24 2.3.4 array_key_exists ............................................................................................ 24 2.3.5 in_array......................................................................................................... 24 2.3.6 array_splice ................................................................................................... 24 2.3.7 array_unique.................................................................................................. 25 2.3.8 array_filter..................................................................................................... 25 2.3.9 array_intersect ............................................................................................... 26 2.3.10 array_merge .............................................................................................. 26 2.4 String Functions ................................................................................................. 26 2.4.1 md5 .............................................................................................................. 26 2.4.2 sha1.............................................................................................................. 26 2.4.3 number_format .............................................................................................. 26 2.4.4 parse_str ....................................................................................................... 27 2.4.5 str_replace..................................................................................................... 27 2.4.6 str_ireplace.................................................................................................... 27 2.4.7 addslashes..................................................................................................... 27 2.4.8 stripslashes.................................................................................................... 27 2.4.9 strlen ............................................................................................................ 27 2.4.10 strtolower .................................................................................................. 27 2.4.11 strtoupper.................................................................................................. 27 2.4.12 substr........................................................................................................ 27 2.4.13 trim........................................................................................................... 28 2.4.14 sprintf ....................................................................................................... 28 2.4.15 sscanf........................................................................................................ 28 2.4.17 implode ..................................................................................................... 28 2.4.18 explode ..................................................................................................... 28 2.4.19 htmlspecialchars......................................................................................... 28 2.4.20 htmlentities................................................................................................ 29 2.4.21 html_entity_decode .................................................................................... 29 2.5 Class and Objects ............................................................................................... 29 Bagian 3 – Using MySQL........................................................................................................... 30 3.1 Membuat database baru ..................................................................................... 31 3.2 Membuat tabel baru ........................................................................................... 31 3.3 Mengubah struktur tabel ..................................................................................... 32 PHP Web Development
Page 2 of 60
3.4 Memanipulasi record dalam tabel......................................................................... 32 3.5 Backup database/tabel to Script........................................................................... 32 Bagian 4 – Integrating PHP dan MySQL........................................................................................... 37 4.2 menghitung jumlah record .................................................................................. 38 4.3 mengubah data di database ................................................................................ 38 Bagian 5 – Data Manipulation ..................................................................................................... 40 Bagian 6 – Paging dan Filtering................................................................................................... 50 6.1 Paging............................................................................................................... 50 6.2 Searching .......................................................................................................... 51 Bagian 7 – Session dan Cookies .................................................................................................. 52 7.1 Session.............................................................................................................. 52 7.2 Cookies ............................................................................................................. 53 8.1 Baca file ............................................................................................................ 55 8.2 Tulis file ............................................................................................................ 55 8.3 Menampilkan isi direktori..................................................................................... 55 8.4 Mengubah nama file ........................................................................................... 55 8.5 Menghapus suatu file.......................................................................................... 56 8.6 Menampilkan file dengan berbagai format ............................................................ 56 8.7 Uploading files ................................................................................................... 56 Bagian 9 – Shopping Cart ......................................................................................................... 58
PHP Web Development
Page 3 of 60
Bagian 1 - Instalasi dan Pengenalan PHP 1.1 Instalasi PHP Langkah-langkah menginstal PHP 1. Copykan file php ke C:\PHP. Kemudian copy file php4ts.dll ke C:\windows\system32 2. Masuk ke C:\PHP, kemudian duplikatkan file php.ini-dist menjadi php.ini Kemudian rename file tersebut menjadi php.ini dan copykan ke C:\WINDOWS 1.2 Instalasi Apache Server 1.3.33 1. Instal Apache terlebih dahulu.
PHP Web Development
Page 4 of 60
2. Pilihlah mode Complete.
PHP Web Development
Page 5 of 60
3. Kemudian klik Next terus hingga proses instalasi dilakukan.
4. Tunggu hingga instalasi selesai.
Kemudian kita lanjutkan dengan setting sebagai berikut 5. Apache anda secara default terinstal di C:\Program Files\Apache Group\Apache Kemudian cari folder conf dan cek di dalamnya terdapat file httpd.conf, buka dengan menggunakan Notepad dan tambahkan 3 baris ini di bagian paling bawah : LoadModule php4_module c:/php/sapi/php4apache.dll AddModule mod_php4.c AddType application/x-httpd-php .php
PHP Web Development
Page 6 of 60
6. Restart apache. Masuk ke services.msc, dengan memilih Start > Run, kemudian ketik services.msc. Setelah itu restart Apache-nya.
PHP Web Development
Page 7 of 60
7. Masuk ke C:\Program Files\Apache Group\Apache\htdocs, kemudian buat folder test, di dalam folder tersebut buat file test.php. Isi test.php dengan sintaks dibawah ini :
8. Buka Browser anda dan ketik http://localhost/test/test.php
Jika muncul tampilan seperti di atas berarti PHP anda telah terinstal dan siap digunakan. Dalam httpd.conf (C:\Program Files\Apache Group\Apache\conf) terdapat beberapa setting yang bersifat optional. Di dalam file httpd.conf cari teks documentroot: kemudian kita bisa mengganti path directory yang diinginkan untuk menaruh file-file PHPnya. Selain itu anda juga harus mengubah tag Directory yang letaknya di bawah tak jauh dari documentroot.
PHP Web Development
Page 8 of 60
Pada satu komputer bisa menggunakan beberapa web server, seperti IIS misalnya untuk ASP, Apache Tomcat untuk JSP, di mana masing-masing web server tersebut harus dibedakan portnya. Jika dalam komputer anda terdapat lebih dari satu web server pastikan setiap web server menggunakan port yang berbeda. Untuk mengubah Port search port: pada file httpd.conf defaultnya adalah 80 bisa anda ubah dengan port lain misalkan 8080. Setelah diubah untuk mengaksesnya menggunakan http://localhost:8080
PHP Web Development
Page 9 of 60
1.3 Instalasi MySQL Server MySQL Server digunakan sebagai database server. Untuk instalasinya sangat mudah jalankan saja Setup dan ikuti wizard hingga instalasi selesai. Secara default mysql akan diinstal pada folder C:\mysql Setelah selesai install, MySQL perlu kita aktifkan untuk pertama kali. Masuklah ke C:\mysql\bin jalankan program winmysqladmin.exe, masukkan nama username misalnya root dan passwordnya misalkan root.
Setelah itu MySQL siap digunakan. Untuk mempermudah pengaksesan ke MySQL kita gunakan tool tambahan yang bernama SQLYog. SQLYog merupakan sebuah tool untuk mempermudah mengatur dan memanipulasi database di MySQL Server. 1.4 PHP Language Fundamental Struktur pemrograman php diawali dengan tag . PHP Introduction PHP Web Development
Page 10 of 60
Pada penulisannya script PHP dapat disisipkan di antara tag-tag HTML. Sebelum masuk ke scripting PHP kita akan review tag-tag HTML yang sering dipakai terlebih dahulu. 1.4.1 HTML Tags HTML(Hypertext Markup Language) adalah suatu standar bahasa yang digunakan untuk membuat halaman web. File-file ini memiliki ekstensi .htm atau .html Coding di dalam HTML menggunakan tag-tag dalam penulisannya. Bagian-bagian dari coding Html tersebut antara lain. Latihan1 Selamat Datang di Web Kami Adalah tag utama dimana tag-tag lain akan diletakan di dalamnya. Adalah tag untuk menuliskan Header dari halaman web yang kita buat. Di dalamnya terdapat beberapa tag lain seperti , , , dan sebagainya. Adalah tag untuk menuliskan judul dari halaman Html yang anda buat. Tag title diletakkan di dalam tag head. Adalah tag utama dari halaman web. Dimana biasanya pada tag ini berisi table, gambar, atau informasi yang ingin ditampilkan di halaman web.
PHP Web Development
Page 11 of 60
Menampilkan text dengan menggunakan div dapat kita atur alignmentnya. Selamat Datang di Web Kami Selamat Datang di Web Kami Selamat Datang di Web Kami Masing-masing akan menampilkan alignment yang berbeda, di tengah, rata kiri dan rata kanan. Menampilkan teks dalam bentuk tabel Adalah tag yang digunakan untuk membuat tabel. Adalah tag yang digunakan untuk membuat baris (row) dari tabel. Adalah tag yang digunakan untuk membuat column dari tabel. Untuk membuat table dengan 4 kolom dan 3 baris maka Nama Tanggal Lahir Alamat No Telp
PHP Web Development
Page 12 of 60
Kita dapat menggunakan berbagai macam properti dari tabel. Sebagai contoh misalkan kita ingin tampilan seperti berikut ini.
JUDUL KOLOM KIRI KOLOM TENGAH KOLOM KANAN PHP Web Development
Page 13 of 60
Dalam suatu tabel dapat kita sisipkan tabel lagi. Pada bagian kolom kiri kita ubah menjadi sebagai berikut. JUDUL 1 2 3 KOLOM TENGAH KOLOM KANAN
PHP Web Development
Page 14 of 60
Adalah tag yang digunakan untuk membuat form. Di mana di dalamnya dapat kita letakan beberapa object seperti textfield, radiobutton, checkbox, dan sebagainya. Form sering digunakan untuk meminta input dari user yang kemudian akan dikirimkan untuk diproses.
Nama Jenis Kelamin Pria Wanita No Telp Pada code di atas menampilkan cara membuat form dan menggunakan tag input. Untuk lebih detailnya mengenai tag input dapat lihat HTML Manualnya. PHP Web Development
Page 15 of 60
1 2 3 4
Pada tag select terdapat attribute multiple untuk memberikan kesan tampilan yang berbeda.
PHP Web Development
Page 16 of 60
Gado-gado Ketoprak Nasi Uduk Nasi Goreng Nasi Tim Kwetiau Goreng Kwetiau Siram Nasi Gila
Untuk meminta input lebih lebih dari satu baris dapat menggunakan textarea.
text here Using Checkbox Checkbox digunakan untuk meminta input lebih dari satu. Send Me Email Send Me Gift Using RadioButton RadioButton digunakan untuk meminta input di mana user hanya boleh memilih salah satu. Untuk penamaan pada radiobutton untuk yang satu group beri nama yang sama pada attribute name.
PHP Web Development
Page 17 of 60
Male Female
1.4.2 Variabel dalam PHP Dalam PHP semua variabel diawali dengan tanda $. Variabel langsung dapat digunakan tapa harus dideklarasikan terlebih dahulu.
1.4.3 Control Structure Untuk struktur pemilihan dan perulangan adalah sebagai berikut: Struktur pemilihan
PHP Web Development
Page 18 of 60
Struktur perulangan
1.4.4 Including PHP script Kita dapat menyertakan suatu halaman php di dalam halaman php lain dengan menggunakan include. Misalkan kita membuat dua halaman satu.php dan dua.php. satu.php
PHP Web Development
Page 19 of 60
dua.php Include Test
Variabel yang dideklarasikan pada halaman utama dapat digunakan pada halaman yang diinclude. tiga.php
empat.php
PHP Web Development
Page 20 of 60
Bagian 2 – Language Fundamental (Lanjutan) 2.1 Function Pada halaman PHP kita dapat mendefinisikan fungsi. Contohnya sebagai berikut:
Kita dapat juga mengirimkan passing parameter. Selain itu fungsi juga dapat mengembalikan suatu nilai (return value).
PHP Web Development
Page 21 of 60
2.2 Array Array dalam PHP sifatnya sangat dinamis. Array terdiri dari pasangan key dan value. Di mana key dapat berupa angka atau string.
echo $arr["foo"]; // bar echo $arr[12]; // 1
$arr = array("somearray" => array(6 => 5, 13 => 9, "a" => 42)); echo $arr["somearray"][6]; echo $arr["somearray"][13]; echo $arr["somearray"]["a"];
// 5 // 9 // 42
// This array is the same as ... array(5 => 43, 32, 56, "b" => 12); // ...this array array(5 => 43, 6 => 32, 7 => 56, "b" => 12);
Untuk menelusuri elemen-elemen dalam array dapat menggunakan for each.
PHP Web Development
red? blue? green? yellow?
Page 22 of 60
2.3 Array Functions 2.3.1 count Untuk menghitung jumlah elemen dalam suatu array. format: int count ( mixed var) $colors = array('red', 'blue', 'green', 'yellow'); echo count($colors);
//output 4
2.3.2 array_keys Untuk mendapatkan array dari semua key dari array. Elemen-elemen akan disusun mulai dari indeks 0. format: array array_keys ( array input [, mixed search_value]) $array = array (0 => 100, "color" => "red"); print_r(array_keys ($array)); $array = array ("blue", "red", "green", "blue", "blue"); print_r(array_keys ($array, "blue")); $array = array ("color" => array("blue", "red", "green"), "size" => array("small", "medium", "large")); print_r(array_keys ($array)); Output: Array ( [0] [1] ) Array ( [0] [1] [2] ) Array ( [0] [1] )
=> 0 => color
=> 0 => 3 => 4
=> color => size
PHP Web Development
Page 23 of 60
2.3.3 array_values Untuk mendapatkan array dari semua value dari array. Elemen-elemen akan disusun mulai dari indeks 0. format: array array_values ( array input) $data = array( “name” => “evo”, “age” => 18 ); $keys = array_keys($data); print_r($keys); /* output Array ( 0 => “evo”, 1 => 18 ); */
2.3.4 array_key_exists Fungsi ini mengembalikan nilai Boolean true atau false di mana memeriksa apakah suatu key ada di dalam suatu array. format: bool array_key_exists ( mixed key, array search) $data = array( “name” => “evo”, “age” => 18 ); if(array_key_exists(“name”, $data)){ echo “found”; }
2.3.5 in_array Fungsi ini hampir sama dengan array_key_exists hanya saja yang dibandingkan adalah value bukan key. 2.3.6 array_splice Fungsi ini digunakan untuk mengambil sebagian dari suatu array. format: array array_slice ( array array, int offset [, int length]) Jika offset bernilai positif, urutan hasilnya akan mulai dari offset tersebut, jika negative maka akan mulai dari belakang array.
PHP Web Development
Page 24 of 60
Jika length bernilai positif maka urutan hasilnya akan sejumlah length. Tetapi jika negative maka urutan akan stop dihitung dari elemen terkahir, jika dikosongkan maka akan diteruskan hingga akhir array. $input = array ("a", "b", "c", "d", "e"); $output $output $output $output
2.3.7
= = = =
array_slice array_slice array_slice array_slice
($input, ($input, ($input, ($input,
2); 2, -1); -2, 1); 0, 3);
// // // //
returns returns returns returns
"c", "d", and "e" "c", "d" "d" "a", "b", and "c"
array_unique
Fungsi ini digunakan untuk menghilangkan value yang terdapat duplikasi. format: array array_unique ( array array) $input = array ("a" => "green", "red", "b" => "green", "blue", "red"); $result = array_unique ($input); print_r($result);
2.3.8
array_filter
Fungsi ini digunakan untuk memfilter elemen-elemen dalam array dengan menggunakan suatu fungsi. format: array array_filter ( array input [, callback function]) function odd($var) { return ($var % 2 == 1); } function even($var) { return ($var % 2 == 0); } $array1 = array ("a"=>1, "b"=>2, "c"=>3, "d"=>4, "e"=>5); $array2 = array (6, 7, 8, 9, 10, 11, 12); echo "Odd :\n"; print_r(array_filter($array1, "odd")); echo "Even:\n"; print_r(array_filter($array2, "even"));
PHP Web Development
Page 25 of 60
2.3.9
array_intersect
Fungsi ini digunakan untuk mencari interseksi dari beberapa array. format: array array_intersect(array arr1, array arr2 [, array ...]) $array1 = array ("a" => "green", "red", "blue"); $array2 = array ("b" => "green", "yellow", "red"); $result = array_intersect ($array1, $array2);
2.3.10 array_merge Fungsi ini digunakan untuk menggabungkan beberapa array. format: array array_merge(array arr1, array arr2 [, array ...])
$array1 = array ("color" => "red", 2, 4); $array2 = array ("a", "b", "color" => "green", "shape" => "trapezoid", 4); $result = array_merge ($array1, $array2); print_r($result); Untuk fungsi-fungsi array lainnya masih banyak. Untuk lebih lengkap dapat dilihat di PHP Manual. 2.4 String Functions 2.4.1 md5 Digunakan untuk enkripsi satu arah dengan metode MD5. Hasil dari md5 adalah string sepanjang 32 karakter. 2.4.2 sha1 Digunakan untuk enkripsi selain md5, menggunakan algoritma sha1. 2.4.3 number_format Digunakan untuk mem-format tampilan suatu bilangan numerik. $number = 1234.56; $english_format_number = number_format($number);
// 1,234
$nombre_format_francais = number_format($number, 2, ',', ' '); // 1 234,56 $number = 1234.5678; $english_format_number = number_format($number, 2, '.', ''); // 1234.57
PHP Web Development
Page 26 of 60
2.4.4 parse_str Digunakan untuk memparsing suatu string ke dalam variabel atau array. $str = "first=value&arr[]=foo+bar&arr[]=baz"; parse_str($str); echo $first; // value echo $arr[0]; // foo bar echo $arr[1]; // baz parse_str($str, $output); echo $output['first']; // value echo $output['arr'][0]; // foo bar echo $output['arr'][1]; // baz 2.4.5 str_replace Digunakan untuk mengganti suatu string dalam string dengan string baru. $bodytag = str_replace("%body%", "black", ""); echo $bodytag; // 2.4.6 str_ireplace Sama seperti str_replace hanya bersifat incase-sensitive. 2.4.7 addslashes Menambahkan backslash untuk karakter-karakter yang membutuhkan backslash sebelum digunakan dalam query ke database. Karakter yang ditambahkan backslash adalah single-quote ( ‘ ), double-quote ( “ ), backslash ( \ ) dan NUL. 2.4.8 stripslashes Menghilangkan tanda backslash pada suatu string. Tanda \’ akan menjadi ‘ saja. 2.4.9 strlen Mendapatkan panjang dari suatu string. 2.4.10 strtolower Mengembalikan nilai string dengan huruf kecil. 2.4.11 strtoupper Mengembalikan nilai string dengan huruf kapital. 2.4.12 substr Mengambil sebagian dari keseluruhan string. $rest $rest $rest $rest
= = = =
substr("abcdef", substr("abcdef", substr("abcdef", substr("abcdef",
$string = 'abcdef'; echo $string{0}; echo $string{3};
PHP Web Development
1); 1, 3); 0, 4); 0, 8);
// // // //
returns returns returns returns
"bcdef" "bcd" "abcd" "abcdef"
// returns a // returns d
Page 27 of 60
2.4.13 trim Mengembalikan string dengan menghilangkan spasi pada bagian awal dan akhir. 2.4.14 sprintf Mengembalikan string sesuai dengan format. $name = ”John”; $age = 18; $result = sprintf(“My name is %s. I am $age years old”,$name,$age); echo $result; 2.4.15 sscanf 2.4.16 sscanf(“5 6 7”,$a,$b,$c); echo $a; echo $b; echo $c; 2.4.17 implode 2.4.18 explode 2.4.19 htmlspecialchars Menerjemahkan karakter khusus pada HTML di mana: format: string htmlspecialchars ( string string [, int quote_style [, string charset]]) • • • • •
&' (ampersand) menjadi '&' '"' (double quote) menjadi '"' pada saat ENT_NOQUOTES tidak diset. ''' (single quote) menjadi ''' hanya pada saat ENT_QUOTES diset. '' (greater than) menjadi '>'
PHP Web Development
Page 28 of 60
2.4.20 htmlentities Menerjemahkan semua karakter ke bentuk standar dalam format HTML. 2.4.21 html_entity_decode Menerjemahkan HTML entities menjadi karakter tertentu. & akan diubah menjadi &. 2.5 Class dan Objects Kita dapat mendeklarasikan class dalam PHP. Sintaksnya adalah sebagai berikut: Person.inc
function isOld(){ return ($this->age>=50); }
TestPerson.php
PHP Web Development
Page 29 of 60
Bagian 3 – Using MySQL Pastikan MySQL Server sudah aktif.
Kemudian jalankan program SQLYog yang sudah terinstall.
Default Host Address adalah localhost, username root, dan password dikosongkan.
database aktif
database explorer
code editor
result view
PHP Web Development
Page 30 of 60
3.1 Membuat database baru Untuk membuat database baru, klik kanan pada database explorer, pilih Create Database (Ctrl+D). Kemudian masukkan nama database.
create database mydatabase; 3.2 Membuat tabel baru Untuk membuat tabel baru klik kanan pada database kemudian pilih Create Table In The Database atau tekan tombol Insert. Kemudian masukkan struktur tabel yang diinginkan.
Kemudian klik tombol Create Table di bagian bawah. Masukkan nama tabel. Hasilnya akan tampil di database explorer.
PHP Web Development
Page 31 of 60
3.3 Mengubah struktur tabel Untuk mengubah struktur tabel, klik kanan pada tabel yang ingin diubah, pilih Alter Table Structure (F6). 3.4 Memanipulasi record dalam tabel Untuk memanipulasi record dalam tabel, pilih tabelnya, kemudian pilih Insert/Update Data atau tekan F11. 3.5 Backup database/tabel to Script Untuk melakukan backup database/tabel yang sudah kita buat dalam bentuk SQL Script, pilih database/tabel yang ingin di-backup, pilih Export As Batch Scripts. SQL Basics Pada bagian ini kita akan membahas sintaks-sintaks untuk memanipulasi data pada database yang dikenal dengan nama DML ( Data Manipulation Language ). Misalkan kita mempunyai struktur tabel sebagai berikut: create table PhoneBook( Nomor int not null, Nama varchar(20), TanggalLahir datetime, Alamat varchar(200), JenisKelamin char(1), Telepon varchar(15), Primary key (Nomor) ) Perintah perintah tersebut antara lain : INSERT Insert adalah perintah sql untuk memasukkan suatu data baru ke dalam suatu table. Format perintah ini adalah
Insert into values insert into Phonebook values(1,'Budi',2020-12-20,'Jalan Mangga 12','L','021-5682771',30) Maka Data baru dengan Nomor,Nama,TanggalLahir,Alamat,JenisKelamin dan telepon akan ditambahkan ke Dalam tabel PhoneBook. atau insert into Phonebook(Nomor,Nama) values(1,'Budi')
PHP Web Development
Page 32 of 60
Pada contoh di atas kita hanya memberi nilai ke Nomor dan Nama, maka kolom yang lain akan bernilai null, hal ini diperbolehkan jika pada saat membuat tabel kita mengizinkan nilai null pada kolom tersebut. Jika memberikan nilai default maka nilai yang akan diberikan pada saat kita tidak member nilai adalah nilai defaultnya bukan nilai null. SELECT Select adalah perintah sql yang berguna untuk mengambil data yang terdapat di dalam database sesuai yang kita inginkan Format perintah ini adalah
Select , from [ where ] [ group by … ] [ having condition ] [ order by ] select * from Phonebook
select Nomor,Nama from Phonebook where Nomor=1 Maka Query akan menghasilkan semua data yang memiliki Nomor 1 dari tabel Phonebook.
Menampilkan semua data yang berumur >= 20 dan jenis kelaminnya laki-laki. select * from PhoneBook where Umur >= 20 AND JenisKelamin='L' Menampilkan semua data yang berumur lebih besar dari 40 tahun atau lebih kecil dari 20 tahun. select * from PhoneBook where Umur > 40 OR Umur < 20 Menampilkan Nomor, Nama, JenisKelamin, Umur diurutkan dari yang paling tua hingga yang paling muda. select Nomor,Nama,JenisKelamin,Umur from PhoneBook order by Umur DESC
PHP Web Development
Page 33 of 60
Menampilkan Nomor, Nama, JenisKelamin, Umur diurutkan dari yang paling tua hingga yang paling muda. select Nomor,Nama,JenisKelamin,Umur from PhoneBook order by Umur ASC Note: untuk ASC boleh tidak ditulis. UPDATE Update adalah perintah sql untuk mengubah satu atau lebih data yang terdapat di dalam suatu table. Format perintah ini adalah
Update set , , … where update PhoneBook set Nama='Andi' where Nomor=2 Maka Nama dari tabel Phonebook dengan nomor 2 akan diubah namanya menjadi Andi. Menambahkan umur semuanya sebesar 1. update PhoneBook set Umur=Umur+1 DELETE Delete adalah perintah sql untuk menghapus satu atau lebih data yang terdapat di dalam suatu table. Format perintah ini adalah
Delete from where delete from PhoneBook WHERE Nomor=1 Maka yang nomor 1 akan dihapus dari tabel. Menghapus semua data dari dalam tabel. delete from PhoneBook Semua data dalam tabel akan dihapus, tetapi struktur tabelnya tetap. Jika kita ingin menghapus tabelnya dari database dapat menggunakan sintaks berikut ini. Tabel berserta data di dalamnya akan dihapus semua.
PHP Web Development
Page 34 of 60
Menghapus tabel dari database drop table PhoneBook Menggunakan Aggregate Function MAX digunakan untuk mengambil nilai maksimal dari suatu field select max(Umur) as MaxUmur from PhoneBook
MIN digunakan untuk mengambil nilai Minimal dari suatu field select min(Umur) as MinUmur from PhoneBook
AVG digunakan untuk mengambil rata-rata dari suatu kolom. select avg(Umur) as RataRataUmur from PhoneBook
SUM digunakan untuk menghitung Jumlah Total dari suatu kolom pada tabel. select sum(Umur) as TotalUmur from PhoneBook
PHP Web Development
Page 35 of 60
Count digunakan untuk menghitung jumlah record yang terdapat pada suatu kolom dari suatu tabel. select count(Nomor) as JumlahOrang from PhoneBook
Bila Kita ingin menampilkan suatu aggregate function Bersama-sama dengan kolom lain di suatu query, kita harus menggunakan sintaks Group By, Sehingga data yang dihitung oleh aggregate function tersebut akan dikelompokkan berdasarkan kolom yang kita GroupBy tersebut. Misalkan kita ingin menampilkan kolom JenisKelamin dengan jumlah orangnya select JenisKelamin,count(Nomor) as Jumlah from PhoneBook group by JenisKelamin
Jika kondisi yang kita gunakan menggunakan aggregate function maka tidak boleh diletakkan di WHERE tetapi harus menggunakan HAVING. select JenisKelamin,count(Nomor) as Jumlah from PhoneBook group by JenisKelamin having count(Nomor)=MAX(Nomor) Menggunakan Limit select * from PhoneBook limit 0,10 sintaks di atas akan menampilkan data dari tabel PhoneBook mulai dari indeks 0 (record pertama) dan seterusnya hingga mencapai 10 record. Dengan sintaks di atas maka hanya 10 record pertama yang akan tampil.
PHP Web Development
Page 36 of 60
Bagian 4 – Integrating PHP dan MySQL Pada bagian ini kita akan mengintegrasikan PHP dengan MySQL. PHP menyediakan fungsi-fungsi untuk melakukan koneksi ke MySQL, mengambil data, mengupdate data, dan operasi database lainnya. connection.inc
= = = =
“localhost”; “root”; “”; “mydatabase”;
//database server, bisa menggunakan IP //user login ke database //password untuk login ke database //nama database
testconnection.php Setiap ingin melakukan koneksi ke database digunakan fungsi mysql_connect, kemudian untuk memlilih database digunakan mysql_select_db, untuk menutup koneksi gunakan mysql_close
4.1 membaca data dari database – mysql_fetch_array
PHP Web Development
Page 37 of 60
4.2 menghitung jumlah record – mysql_num_rows 4.3 mengubah data di database – mysql_query
PHP Web Development
Page 38 of 60
4.4 mendapatkan informasi kolom dari suatu tabel – mysql_num_fields, mysql_fetch_field
PHP Web Development
Page 39 of 60
Bagian 5 – Data Manipulation Pada bagian ini kita akan membuat halaman web untuk memanipulasi data. Struktur tabel yang digunakan adalah sebagai berikut:
Untuk field id dibuat primary key dan auto Increment Struktur webnya adalah sebagai berikut:
show.php add_form.php edit_form.php delete_form.php add_process.php edit_process.php delete_process.php includes images styles.css
-
PHP Web Development
halaman menampilkan semua data dari database halaman form input user untuk tambah data halaman form edit user untuk ubah data halaman form untuk konfirmasi penghapusan data halaman untuk proses tambah data halaman untuk proses ubah data halaman untuk proses delete data folder template script php yang di-include. folder untuk menyimpan gambar-gambar file untuk setting CSS (Cascading Stylesheet)
Page 40 of 60
includes/connection.php includes/header.php My PhoneBook Version 1.00 styles.css BODY { font-family: Verdana, Arial, Tahoma; font-size: X-Small; } .mylink { font-family: Verdana, Arial, Tahoma; font-size: X-Small; color: #00FF00; text-decoration: none; } .mylink:hover { font-family: Verdana, Arial, Tahoma; font-size: X-Small; color: #009CC9; text-decoration: underline; } .mylink:visited { font-family: Verdana, Arial, Tahoma; font-size: X-Small; color: #00FF00; text-decoration: none; }
PHP Web Development
Page 41 of 60
show.php Pada halaman ini kita akan menampilkan data dari database dalam bentuk tabel di HTML. My PhoneBook Add new data Name Phone Email ”>delete
PHP Web Development
Page 42 of 60
add_form.php My PhoneBook ID Auto-generated Name Phone Email Birthdate PHP Web Development
Page 43 of 60
Data di dalam form akan dikirimkan ke halaman yang kita spesifikasikan pada attribute action pada form (add_process.php). Berarti untuk code insert ke database akan dituliskan pada halaman add_process.php add_process.php Pada halaman ini, kita tangkap terlebih dahulu data yang dikirimkan dari form. Jika method yang digunakan adalah POST berarti kita gunakan variabel $_POST, jika method yang digunakan adalah GET berarti kita gunakan variabel $_GET
$success = mysql_query($sql); //execute SQL statement mysql_close($con); if($success) header(“location:show.php”); else { echo “Error: ” . mysql_error() . “”; echo ‘Back’; }
PHP Web Development
Page 44 of 60
Perbedaan antara $_POST dan $_GET adalah jika kita menggunakan method get maka nilai-nilai yang dikirimkan akan muncul di url address pada address bar. Sedangkan jika menggunakan POST data tidak akan ditampilkan paa url address. Untuk data yang banyak, seperti registrasi member, ataupun yang tidak ingin ditampilkan, misalkan form login, kita gunakan method POST.
edit_form.php Untuk edit form pada dasarnya hampir sama dengan add_form.php hanya saja pada halaman ini kita akan mengambil nilai yang dipassing dari link pada show.php. Pada saat kita meng-klik pada link edit maka akan diredirect ke halaman edit_form.php dengan mengirimkan id yang akan diedit dengan menggunakan method GET.
Sehingga pada halaman ini kita akan mengambil dulu dari querystring nilai id yang ingin di-edit, kemudian kita ambil detailnya dari database dan kemudian ditampilkan dalam form. Untuk ID akan kita buat readonly sehingga user hanya bisa bisa mengubah nilai dari field-field yang lain saja. My PhoneBook ID ”> Phone ”> Birthdate Pada halaman ini user dapat mengubah nama, phone, email, dan birthdate. Untuk ID kita tambahkan READONLY pada tag input sehingga tidak bisa diubah. Form ini akan dikirim ke edit_process.php dengan method POST. edit_process.php Pada halaman edit_process.php kita dapat menangkap data-data yang dikirimkan dari edit_form.php dan kemudian lakukan proses update ke database.
PHP Web Development
Page 47 of 60
$success = mysql_query($sql); //execute SQL statement mysql_close($con); if($success) header(“location:show.php”); else { echo “Error: ” . mysql_error() . “”; echo ‘Back’; }
delete_form.php Pada delete_form sama seperti halaman edit_form.php. Dapatkan id yang akan didelete dari url dengan $_GET kemudian tampilkan konfirmasi menggunakan form. User dapat memilih untuk klik button yes atau no. Untuk mengirimkan id lewat form kita dapat menggunakan hidden field di mana informasinya kita sisipkan tanpa perlu dilihat user. Nilai dari hidden field akan tetap dikirimkan lewat form ke halaman yang dituju. Are you sure ?
}
if($success){ header(“location:show.php”); }else{ echo “Error: ” . mysql_error() . “”; echo ‘Back’; }
Catatan: Untuk pindah ke halaman lain menggunakan header(“location:url.php”) tidak boleh terjadi output ke client. Pastikan fungsi tersebut dipanggil sebelum terjadi output kepada user seperti perintah echo. Selain menggunakan fungsi tersebut dapat juga menggunakan tag meta dari html seperti berikut. header(“location:show.php”); dapat juga dilakukan dengan Dengan tag meta dari HTML tersebut browser akan direfresh dalam waktu 1 detik dan pindah ke halaman show.php. Tag meta ini dapat digunakan walaupun sudah terjadi output kepada client.
PHP Web Development
Page 49 of 60
Bagian 6 – Paging dan Filtering 6.1 Paging Paging adalah suatu teknik untuk menampilkan data dari database per bagian di mana menggunakan konsep halaman.
Pada halaman show.php akan kita modifikasi sedikit untuk memberikan efek paging. ... Add new data ... PHP Web Development
Page 50 of 60
6.2 Searching Pada halaman web kita juga dapat menambahkan fitur searching. Caranya tambahkan sebuah form pada show.php Dengan mengosongkan bagian action, berarti data dalam form akan dikirimkan ke halaman yang sama. Kemudian keyword yang dikirimkan kita tangkap dengan $_POST kemudian kita tambahkan where pada sintaks SQL sebelum dieksekusi dengn mysql_query ... Add new data ... Seharusnya seperti berikut ini: ... Setelah fungsi tersebut dipanggil halaman tersebut dapat menggunakan variabel $_SESSION. session1.php Ke halaman kedua session2.php Session juga dapat dimanfaatkan untuk proses login. Pada saat login berhasil simpanlah suatu nilai misalkan username yang sedang login pada session, kemudian pada saat mengakses suatu halaman yang ingin diproteksi cek terlebih dahulu apakah di session terdapat username yang sedang login jika tidak ada pindahkan ke halaman login. Session secara default disimpan di C:\Windows\Temp (PHP Versi 4.3.9) atau dapat diset dengan menggunakan session_save_path di mana harus dipanggil sebelum session_start() PHP Web Development
Page 52 of 60
Fungsi-fungsi session lainnya: session_destroy() session_id()
-
untuk menghapus session yang sedang aktif untuk mendapatkan/mengeset session id yang digunakan. Untuk mengeset session id fungsi ini harus dipanggil sebelum session_start()
7.2 Cookies Cookies adalah suatu teknik menyimpan suatu nilai pada sisi client, berbeda dengan session yang disimpan di server. Untuk menyimpan nilai cookie digunakan fungsi setcookie. Untuk mengakses nilai cookide digunakan variabel $_COOKIE format: bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, int secure]]]]]) Parameter Keterangan
Contoh
name
nama dari cookie
'cookiename' digunakan dalam $_COOKIE['cookiename']
value
nilai dari cookie
nilai di dapat dari $_COOKIE[“cookiename’]
expire
time()+60*60*24*30 akan menyebabkan cookie berlaku waktu berlaku cookie. dalam detik. fungsi time() selama 30 hari. Jika parameter ini dikosongkan maka biasa digunakan untuk mendapatkan waktu dari cookie akan berlaku hingga akhir session (pada saat sistem browser ditutup) path di server di mana cookie berlaku
Jika menggunakan '/', cookie berlaku untuk keseluruhan domain. Jika diset '/foo/', cookie hanya berlaku untuk direktori /foo/ dan sub-direktorinya. Nilai defaultnya adalah direktori yang sedang aktif.
domain
Nama domain di mana cokie berlaku.
Agar cookie berlaku untuk semua subdomains dari example.com maka set nilainya menjadi '.example.com'. Jika diset dengan www.example.com maka cookiehanya berlaku untuk subdomain www.
secure
mengindikasikan apakah cookie dikirimkan melalui koneksi HTTPS yang secure. Jika diset 1, 0 or 1 cookie hanya dapat diset jika menggunakan SSL secure connection. Nilai defaultnya adalah 0.
path
Untuk menghapus cookie, setcookie dengan waktu yang expired. PHP Web Development
Page 53 of 60
Array of Cookies
PHP Web Development
Page 54 of 60
Bagian 8 – File and Handling Uploads Pada bagian ini kita akan membahas fungsi-fungsi file dan cara mengupload file melalui web dan bagaimana cara penanganannya. 8.1 Baca file- fopen, fread
View more...
Comments