MATERI PART 3 – Prak.
BASISDATA
Q U E R Y
LABORATORIUM 4 – BASISDATA
MENU MINGGU INI
I. SELECT
Statement
1.
Mengambil
data dengan SELECT
2.
Query
menggunakan parameter kondisi WHERE
3.
Query
menggunakan beberapa parameter kondisional
4.
Memberikan
alias hasil query pada SELECT
5.
Query data
bertipe teks dengan pattern matching
6.
Query data
unik menggunakan DISTINCT
7.
Membatasi
hasil query dengan LIMIT
8.
Mengelompokkan
hasil query menggunakan GROUP BY
9.
Mendapatkan
jumlah anggota setiap kelompok menggunakan COUNT()
10. Parameter kondisional dengan HAVING
11. Mengurutkan hasil query menggunakan
ORDER BY
12. Mengurutkan hasil query berdasarkan
lebih dari satu kolom
13. Kombinasi ORDER BY dengan LIMIT
14. Operator BETWEEN
15. MAX,
MIN, AVERAGE data dari tabel
II. SUB
QUERY
1.
Sub query
dengan ALL
2.
Sub query dengan
ANY
3.
Sub query
dengan EXISTS
4.
Sub query
dengan IN
III. Table
Join
1.
Cross Join
2.
Equi-Join
atau Inner Join
3.
Natural
Join
4.
Left Join
dan Right Join
5.
Update
menggunakan Join Table
6.
Delete
menggunakan join table
SELECT Statement
Sebelum
kita memulai pembahsan dengan SELECT terlebih dahulu kita siapkan tabel baru
bernama table pegawai.
mysql> create
table pegawai(nip varchar(8) primary key, nama_peg varchar(50), alamat_peg
varchar(50), jabatan varchar(20), gaji int(7));
Query OK, 0 rows affected (0.70 sec)
mysql> desc
pegawai;
+------------+-------------+------+-----+---------+-------+
|
Field | Type | Null | Key | Default | Extra |
+------------+-------------+------+-----+---------+-------+
|
nip | varchar(8) | NO
| PRI | NULL |
|
|
nama_peg | varchar(50) | YES | |
NULL | |
|
alamat_peg | varchar(50) | YES | | NULL
| |
|
jabatan | varchar(20) | YES | |
NULL | |
|
gaji | int(7) | YES
| | NULL |
|
+------------+-------------+------+-----+---------+-------+
5 rows in set (0.13 sec)
Lalu kita
isikan dengan data yang sudah tersedia
mysql> load data local infile 'D://file.txt'
into table pegawai;
Query OK, 15 rows affected (0.63 sec)
Records: 15 Deleted: 0
Skipped: 0 Warnings: 0
1.
Mengambil Data dengan SELECT
Perintah
select untuk mengambil data sudah sering kita pakai sebelumnya, untuk mengambil
seluruh data yang ada di dalam suatu tabel kita bisa menggunakan perintah SELECT
* FROM <nama_tabel>
CONTOH :
mysql> select * from pegawai;
+----------+-----------------------+-------------+----------------+---------+
|
nip | nama_peg | alamat_peg | jabatan | gaji |
+----------+-----------------------+-------------+----------------+---------+
|
PEG-1001 | Soeharto Mangundirejo | Yogyakarta
| C.E.O | 9000000 |
|
PEG-1002 | Felix Nababan |
Medan | Manager | 8000000 |
|
PEG-1003 | Olga Syahputra |
Jakarta | Kepala Unit | 6000000 |
|
PEG-1004 | Chelsea Olivia |
Bandung | Kepala Unit | 6000000 |
|
PEG-1005 | Tuti Wardani | Jawa
Tengah | Supervisor | 4500000 |
|
PEG-1006 | Budi Drajat |
Malang | Supervisor | 4500000 |
|
PEG-1007 | Bambang Pamungkas |
Kudus | Staff Senior | 3000000 |
|
PEG-1008 | Ely Oktafiani |
Yogyakarta | Staff Senior | 3000000 |
|
PEG-1009 | Rani Wijaya |
Magelang | Staff Senior | 3000000 |
|
PEG-1010 | Rano Karno |
Solo | Staff Junior | 2000000 |
|
PEG-1011 | Rahmadi Sholeh |
Yogyakarta | Staff Junior | 2000000 |
|
PEG-1012 | Ilham Ungara |
Jakarta | Staff Junior | 2000000 |
|
PEG-1013 | Endang Melati |
Madiun | Staff Junior | 2000000 |
|
PEG-1014 | Donny Damara |
Makasar | Tenaga Kontrak | 1000000 |
|
PEG-1015 | Paijem |
Yogyakarta | Tenaga Kontrak | 500000 |
+----------+-----------------------+-------------+----------------+---------+
15 rows in set (0.00 sec)
Perintah diatas menunjukan seluruh dara
dari table pegawai
Kita juga bisa mengambil seluruh data
tapi hanya kolom – kolom tertentu dengan perintah dasar : SELECT
<NAMA_KOLOM, NAMA_KOLOM > FROM <NAMA_TABEL>
CONTOH :
mysql> select nip, nama_peg from
pegawai;
+----------+-----------------------+
|
nip | nama_peg |
+----------+-----------------------+
|
PEG-1001 | Soeharto Mangundirejo |
|
PEG-1002 | Felix Nababan |
|
PEG-1003 | Olga Syahputra |
|
PEG-1004 | Chelsea Olivia |
|
PEG-1005 | Tuti Wardani |
|
PEG-1006 | Budi Drajat |
|
PEG-1007 | Bambang Pamungkas |
|
PEG-1008 | Ely Oktafiani |
|
PEG-1009 | Rani Wijaya |
|
PEG-1010 | Rano Karno |
|
PEG-1011 | Rahmadi Sholeh |
|
PEG-1012 | Ilham Ungara |
|
PEG-1013 | Endang Melati |
|
PEG-1014 | Donny Damara |
|
PEG-1015 | Paijem |
+----------+-----------------------+
15 rows in set (0.00 sec)
2. Query
menggunakan parameter kondisi WHERE
Statement
WHERE disini akan digunakan untuk memfilter atau mengatur kolom dan baris mana
yang akan kita munculkan atau kita ambil.
PERINTAH DASAR :
SELECT
* FROM <nama_table> WHERE <kondisi>
CONTOH :
mysql>
select * from pegawai where jabatan='Staff Junior';
+----------+----------------+------------+--------------+---------+
| nip
| nama_peg | alamat_peg |
jabatan | gaji |
+----------+----------------+------------+--------------+---------+
| PEG-1010 | Rano Karno | Solo | Staff Junior | 2000000 |
| PEG-1011 | Rahmadi Sholeh | Yogyakarta | Staff
Junior | 2000000 |
| PEG-1012 | Ilham Ungara | Jakarta
| Staff Junior | 2000000 |
| PEG-1013 | Endang Melati | Madiun
| Staff Junior | 2000000 |
+----------+----------------+------------+--------------+---------+
4 rows in set (0.44 sec)
Perintah diatas menunjukkan data pegawai
yang difilter berdasarkan jabatan yg berisi staff junior
mysql>
select nip, nama_peg from pegawai where jabatan='Staff Junior';
+----------+----------------+
| nip
| nama_peg |
+----------+----------------+
| PEG-1010 | Rano Karno |
| PEG-1011 | Rahmadi Sholeh |
| PEG-1012 | Ilham Ungara |
| PEG-1013 | Endang Melati |
+----------+----------------+
4 rows in set (0.00 sec)
Untuk menampilkan tidak semua data atau
hanya data pada kolom – kolom tertentu yg telah dituliskan dan tetap
berdasarkan jabatan = junior staff
3. Query
menggunakan beberapa parameter kondisional
Perintah
yang digunakan disini menggunakan WHERE tapi yang membedakan perintah yang
digunakan lebih menunjukkan kondisi yang diinginkan, dengan bisa menggunakan
penggabungan beberapa parameter untuk menampilkan data. Penggabungan ini bisa
menggunakan perintah AND atau OR, untuk lebih jelasnya bisa dilihat contoh :
mysql> select * from pegawai
where alamat_peg ='Yogyakarta' AND gaji < 4000000;
+----------+----------------+------------+----------------+---------+
| nip | nama_peg | alamat_peg | jabatan | gaji |
+----------+----------------+------------+----------------+---------+
| PEG-1008 | Ely
Oktafiani | Yogyakarta | Staff
Senior | 3000000 |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta | Staff Junior |
2000000 |
| PEG-1015 | Paijem | Yogyakarta | Tenaga Kontrak | 500000 |
+----------+----------------+------------+----------------+---------+
3 rows
in set (0.00 sec)
Perintah
diatas menunjukkan pemfilteran dengan 2 kondisi yaitu berdasarkan alamat_peg
dan gaji yang kurang dari 4jt
mysql> select nip, nama_peg
from pegawai where alamat_peg ='Yogyakarta' OR alamat_peg ='Jakarta';
+----------+-----------------------+
| nip | nama_peg |
+----------+-----------------------+
| PEG-1001 | Soeharto
Mangundirejo |
| PEG-1003 | Olga
Syahputra |
| PEG-1008 | Ely
Oktafiani |
| PEG-1011 | Rahmadi
Sholeh |
| PEG-1012 | Ilham
Ungara |
| PEG-1015 | Paijem |
+----------+-----------------------+
6 rows
in set (0.00 sec)
Jika
perintah diatas menunjukkan data yang mempunyai alamat di Yogyakarta atau di
Jakarta
4. Memberikan
alias hasil query pada SELECT
Kita
bisa menggunakan perintah SELECT untuk membuat alias pada suatu kolom dengan
perintah AS.
mysql>
select nama_peg AS nama_pegawai, alamat_peg AS asal from pegawai where
alamat_peg='Jakarta';
+----------------+---------+
| nama_pegawai
| asal |
+----------------+---------+
| Olga Syahputra | Jakarta |
| Ilham Ungara
| Jakarta |
+----------------+---------+
2 rows in set (0.00 sec)
Di sini pada saat menampilkan hasil, nama
kolom akan diganti dengan perintah AS
5. Query
data bertipe teks dengan pattern matching
Menampilkan data dengan mencocokan
(matching) dengan kondisi yang kita inginkan.
Dengan menggunakan perintah ‘LIKE’ untuk
perintah ‘seperti’ dan ‘NOT LIKE’ untuk perintah ‘tidak seperti’ dan beberapa
simbol matching yg ada di SQL yaitu ‘_’ dan ‘%’ untuk lebih jelasnya bisa lihat
di contoh :
mysql>
select nama_peg from pegawai where jabatan like 'M______';
+---------------+
| nama_peg
|
+---------------+
| Felix Nababan |
+---------------+
1 row in set (0.00 sec)
Pada perintah diatas menunjukkan bahwa data
yang diminta adalah data yang memuat Jabatan berawalan M dan berjumlah 7 huruf.
mysql>
select nama_peg from pegawai where jabatan like 'M%';
+---------------+
| nama_peg
|
+---------------+
| Felix Nababan |
+---------------+
1 row in set (0.00 sec)
Perintah di atas menunjukkan data yang
diminta adalah data nama pegawai yang jabatannya berawalan huruf ‘M’
mysql>
select nama_peg from pegawai where alamat_peg like '%A';
+-----------------------+
| nama_peg |
+-----------------------+
| Soeharto Mangundirejo |
| Olga Syahputra |
| Ely Oktafiani |
| Rahmadi Sholeh |
| Ilham Ungara |
| Paijem |
+-----------------------+
6 rows in set (0.00 sec)
Perintah di atas menunjukkan data yang
diminta adalah data nama pegawai yang alamatnya berakhiran huruf ‘A’
6. Query
data unik menggunakan DISTINCT
Perintah DISTINCT digunakan untuk menampilkan
data yang unik, jadi jika ada data yang sama tidak akan ditampilkan.
mysql>
select alamat_peg from pegawai;
+-------------+
| alamat_peg
|
+-------------+
| Yogyakarta
|
| Medan
|
| Jakarta
|
| Bandung
|
| Jawa Tengah |
| Malang
|
| Kudus
|
| Yogyakarta
|
| Magelang
|
| Solo
|
| Yogyakarta
|
| Jakarta
|
| Madiun
|
| Makasar
|
| Yogyakarta
|
+-------------+
15 rows in set (0.00 sec)
mysql>
select distinct alamat_peg from pegawai;
+-------------+
| alamat_peg
|
+-------------+
| Yogyakarta
|
| Medan
|
| Jakarta
|
| Bandung
|
| Jawa Tengah |
| Malang
|
| Kudus
|
| Magelang
|
| Solo
|
| Madiun
|
| Makasar
|
+-------------+
11 rows in set (0.05 sec)
7. Membatasi
hasil query dengan LIMIT
Perintah
LIMIT ini akan membatasi jumlah data yang akan kita tampilkan.
mysql> select * from pegawai
LIMIT 5;
+----------+-----------------------+-------------+-------------+---------+
|
nip | nama_peg | alamat_peg | jabatan
| gaji |
+----------+-----------------------+-------------+-------------+---------+
|
PEG-1001 | Soeharto Mangundirejo | Yogyakarta
| C.E.O | 9000000 |
|
PEG-1002 | Felix Nababan |
Medan | Manager | 8000000 |
|
PEG-1003 | Olga Syahputra |
Jakarta | Kepala Unit | 6000000 |
|
PEG-1004 | Chelsea Olivia |
Bandung | Kepala Unit | 6000000 |
|
PEG-1005 | Tuti Wardani | Jawa
Tengah | Supervisor | 4500000 |
+----------+-----------------------+-------------+-------------+---------+
5
rows in set (0.00 sec)
8. Mengelompokkan
hasil query menggunakan GROUP BY
Penampilan data dikelompokkan dengan GROUP
BY, data yang ditampilkan adalah dta pertama dari kolom yang ditunjuk sebagai
parameter GROUP BY.
CONTOH :
mysql>
select * from pegawai GROUP BY gaji;
+----------+-----------------------+-------------+----------------+---------+
| nip
| nama_peg |
alamat_peg | jabatan | gaji |
+----------+-----------------------+-------------+----------------+---------+
| PEG-1015 | Paijem | Yogyakarta | Tenaga Kontrak | 500000 |
| PEG-1014 | Donny Damara | Makasar | Tenaga Kontrak | 1000000 |
| PEG-1010 | Rano Karno | Solo | Staff Junior | 2000000 |
| PEG-1007 | Bambang Pamungkas | Kudus | Staff Senior | 3000000 |
| PEG-1005 | Tuti Wardani | Jawa Tengah | Supervisor | 4500000 |
| PEG-1003 | Olga Syahputra | Jakarta | Kepala Unit | 6000000 |
| PEG-1002 | Felix Nababan | Medan | Manager | 8000000 |
| PEG-1001 | Soeharto Mangundirejo |
Yogyakarta | C.E.O | 9000000 |
+----------+-----------------------+-------------+----------------+---------+
8 rows in set (0.41 sec)
Menunjukkan pengngelompokan data berdasarkan
gaji, jika ada yang memiliki gaji yang sama maka yang ditampilkan adalah data
yang pertama, contoh Rano Karno dan Rahmadi Sholeh sama – sama memiliki gaji
2juta tetapi karena Rano Karno ada diatas Rahmadi maka yang ditampilkan adalah
data dari Rano Karno.
9. Mendapatkan
jumlah anggota setiap kelompok menggunakan COUNT()
Perintah
COUNT() ini berkaitan dengan perintah GROUP BY, yaitu untuk mengetahui jumlah
dari anggota GROUP, untuk lebih jelasnya bisa melihat contoh :
mysql> select gaji, count(*)
FROM pegawai GROUP BY gaji;
+---------+----------+
|
gaji | count(*) |
+---------+----------+
| 500000 | 1 |
|
1000000 | 1 |
|
2000000 | 4 |
|
3000000 | 3 |
|
4500000 | 2 |
|
6000000 | 2 |
|
8000000 | 1 |
|
9000000 | 1 |
+---------+----------+
8
rows in set (0.44 sec)
10.Parameter
kondisional dengan HAVING
Penggunaan
HAVING sangat mirip dengan penggunaan WHERE contoh :
mysql>
select * from pegawai HAVING gaji > 6000000;
+----------+-----------------------+------------+---------+---------+
| nip
| nama_peg |
alamat_peg | jabatan | gaji |
+----------+-----------------------+------------+---------+---------+
| PEG-1001 | Soeharto Mangundirejo | Yogyakarta |
C.E.O | 9000000 |
| PEG-1002 | Felix Nababan | Medan | Manager | 8000000 |
+----------+-----------------------+------------+---------+---------+
2 rows in set (0.00 sec)
Dari contoh diatas bisa terlihat jelas
penggunaan HAVING dan WHERE sangat mirip
11.Mengurutkan
hasil query menggunakan ORDER BY
Perintah
ORDER BY adalah perintah untuk mengurutkan tabel secara ASC atau DESC,
CONTOH
:
mysql> select * from pegawai
ORDER BY nama_peg;
+----------+-----------------------+-------------+----------------+---------+
|
nip | nama_peg | alamat_peg | jabatan | gaji |
+----------+-----------------------+-------------+----------------+---------+
|
PEG-1007 | Bambang Pamungkas |
Kudus | Staff Senior | 3000000 |
|
PEG-1006 | Budi Drajat |
Malang | Supervisor | 4500000 |
|
PEG-1004 | Chelsea Olivia |
Bandung | Kepala Unit | 6000000 |
|
PEG-1014 | Donny Damara |
Makasar | Tenaga Kontrak | 1000000 |
|
PEG-1008 | Ely Oktafiani |
Yogyakarta | Staff Senior | 3000000 |
|
PEG-1013 | Endang Melati |
Madiun | Staff Junior | 2000000 |
|
PEG-1002 | Felix Nababan |
Medan | Manager | 8000000 |
|
PEG-1012 | Ilham Ungara |
Jakarta | Staff Junior | 2000000 |
|
PEG-1003 | Olga Syahputra |
Jakarta | Kepala Unit | 6000000 |
|
PEG-1015 | Paijem |
Yogyakarta | Tenaga Kontrak | 500000 |
|
PEG-1011 | Rahmadi Sholeh |
Yogyakarta | Staff Junior | 2000000 |
|
PEG-1009 | Rani Wijaya |
Magelang | Staff Senior | 3000000 |
|
PEG-1010 | Rano Karno |
Solo | Staff Junior | 2000000 |
|
PEG-1001 | Soeharto Mangundirejo | Yogyakarta
| C.E.O | 9000000 |
|
PEG-1005 | Tuti Wardani | Jawa
Tengah | Supervisor | 4500000 |
+----------+-----------------------+-------------+----------------+---------+
15
rows in set (0.42 sec)
Jika dilihat dari perintah diatas menunjukkan
bahwa perintah ORDER
BY
akan diurutkan secara ASC secara
default.
Untuk perintah ORDER BY secara DESC maka perintahnya sbb :
mysql> select * from pegawai
ORDER BY nama_peg DESC;
+----------+-----------------------+-------------+----------------+---------+
|
nip | nama_peg | alamat_peg | jabatan | gaji |
+----------+-----------------------+-------------+----------------+---------+
|
PEG-1005 | Tuti Wardani | Jawa
Tengah | Supervisor | 4500000 |
|
PEG-1001 | Soeharto Mangundirejo | Yogyakarta
| C.E.O | 9000000 |
|
PEG-1010 | Rano Karno | Solo | Staff Junior | 2000000 |
|
PEG-1009 | Rani Wijaya |
Magelang | Staff Senior | 3000000 |
|
PEG-1011 | Rahmadi Sholeh |
Yogyakarta | Staff Junior | 2000000 |
|
PEG-1015 | Paijem |
Yogyakarta | Tenaga Kontrak | 500000 |
|
PEG-1003 | Olga Syahputra |
Jakarta | Kepala Unit | 6000000 |
|
PEG-1012 | Ilham Ungara |
Jakarta | Staff Junior | 2000000 |
|
PEG-1002 | Felix Nababan |
Medan | Manager | 8000000 |
|
PEG-1013 | Endang Melati |
Madiun | Staff Junior | 2000000 |
|
PEG-1008 | Ely Oktafiani |
Yogyakarta | Staff Senior | 3000000 |
|
PEG-1014 | Donny Damara |
Makasar | Tenaga Kontrak | 1000000 |
|
PEG-1004 | Chelsea Olivia |
Bandung | Kepala Unit | 6000000 |
|
PEG-1006 | Budi Drajat |
Malang | Supervisor | 4500000 |
|
PEG-1007 | Bambang Pamungkas |
Kudus | Staff Senior | 3000000 |
+----------+-----------------------+-------------+----------------+---------+
15
rows in set (0.00 sec)
12.Mengurutkan
hasil query berdasarkan lebih dari satu kolom
Pada perintah ini pengurutan data dilakukan
tidak hanya berdasar 1 kolom, tetapi berdasar 2 kolom atau lebihpun bisa.
Agar data bisa terlihat jelas maka coba buat
tabel pegawai2 dengan rincian sbb :
mysql> create table pegawai2(nama
varchar(20), alamat varchar(20));
Query OK, 0 rows affected (0.47 sec)
mysql> desc pegawai2;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| nama |
varchar(20) | YES | | NULL
| |
| alamat | varchar(20) | YES | |
NULL | |
+--------+-------------+------+-----+---------+-------+
2 rows in set (0.11 sec)
mysql> select*from pegawai2;
+------+------------+
| nama | alamat |
+------+------------+
| Zeze | Yogyakarta |
| Zeze | Jakarta |
| Riza | Bandung |
| Riza | Aceh |
| Amir | Demak |
| Amir | Cilacap |
+------+------------+
6 rows in set (0.00 sec)
Kita sudah punya tabel baru yang menunjukkan
data pada kolom nama ada yang sama, tapi di kolom alamat berbeda maka bisa
diurutkan sbb :
mysql>
select nama, alamat from pegawai2 ORDER BY nama, alamat;
+------+------------+
| nama | alamat |
+------+------------+
| Amir | Cilacap |
| Amir | Demak |
| Riza | Aceh |
| Riza | Bandung |
| Zeze | Jakarta |
| Zeze | Yogyakarta |
+------+------------+
6 rows in set (0.00 sec)
mysql>
select * from pegawai2 ORDER BY nama, alamat desc;
+------+------------+
| nama | alamat |
+------+------------+
| Amir | Demak |
| Amir | Cilacap |
| Riza | Bandung |
| Riza | Aceh |
| Zeze | Yogyakarta |
| Zeze | Jakarta |
+------+------------+
6 rows in set (0.00 sec)
Pada tabel ini telah diurutkan nama terlebih
dahulu seteleh itu baru mengurutkan berdasarkan alamat.
13.Kombinasi
ORDER BY dengan LIMIT
Perintah ORDER BY juga bisa dikombinasikan
dengan perintah LIMIT, contohnya
mysql> select * from pegawai ORDER BY
gaji LIMIT 5;
+----------+----------------+------------+----------------+---------+
| nip
| nama_peg | alamat_peg |
jabatan | gaji |
+----------+----------------+------------+----------------+---------+
| PEG-1015 | Paijem | Yogyakarta | Tenaga Kontrak | 500000 |
| PEG-1014 | Donny Damara | Makasar
| Tenaga Kontrak | 1000000 |
| PEG-1013 | Endang Melati | Madiun
| Staff Junior | 2000000 |
| PEG-1012 | Ilham Ungara | Jakarta
| Staff Junior | 2000000 |
| PEG-1011 | Rahmadi Sholeh | Yogyakarta | Staff
Junior | 2000000 |
+----------+----------------+------------+----------------+---------+
5 rows in set (0.00 sec)
Contoh diatas menunjukkan 5 gaji terendah di
table pegawai.
14.Operator
BETWEEN
Perintah BETWEEN digunakan untuk memfilter
data diantara dua nilai yang dispesifikkan
mysql>
select * from pegawai WHERE gaji BETWEEN 4000000 AND 9000000;
+----------+-----------------------+-------------+-------------+---------+
| nip
| nama_peg |
alamat_peg | jabatan | gaji
|
+----------+-----------------------+-------------+-------------+---------+
| PEG-1001 | Soeharto Mangundirejo |
Yogyakarta | C.E.O | 9000000 |
| PEG-1002 | Felix Nababan | Medan | Manager | 8000000 |
| PEG-1003 | Olga Syahputra | Jakarta | Kepala Unit | 6000000 |
| PEG-1004 | Chelsea Olivia | Bandung | Kepala Unit | 6000000 |
| PEG-1005 | Tuti Wardani | Jawa Tengah | Supervisor | 4500000 |
| PEG-1006 | Budi Drajat | Malang | Supervisor | 4500000 |
+----------+-----------------------+-------------+-------------+---------+
6 rows in set (0.00 sec)
Perintah diatas menunjukkan penampilan gaji
diantara 4jt dan 9jt .
Jika perintah BETWEEN dilakukan untuk
mencari data dalam range, ada juga NOT
BETWEEN untuk mencari data diluar range yang kita tentukan.
CATATAN
: penginputan range diawali dengan urutan yang lebih kecil, contoh 4jt – 9jt,
atau Ely O – Olga S
mysql>
select nama_peg, gaji from pegawai WHERE nama_peg NOT BETWEEN "Ely Oktafi
ani"
AND "Olga Syahputra";
+-----------------------+---------+
|
nama_peg | gaji |
+-----------------------+---------+
|
Soeharto Mangundirejo | 9000000 |
|
Chelsea Olivia | 6000000 |
|
Tuti Wardani | 4500000 |
|
Budi Drajat | 4500000 |
|
Bambang Pamungkas | 3000000 |
|
Rani Wijaya | 3000000 |
|
Rano Karno | 2000000 |
|
Rahmadi Sholeh | 2000000 |
|
Donny Damara | 1000000 |
|
Paijem | 500000 |
+-----------------------+---------+
10 rows in set (0.00 sec)
Menunjukkan hasil dari NOT BETWEEN dalam
menampilkan data yang bukan antara Ely Oktafiani dan Olga Syahputra
15.MAX, MIN, AVERAGE data dari
tabel
Perintah untuk menunjukkan nilai
maksimal atau minimal ataupun nilai rata – rata juga bisa kita lakukan di
MySQL, dengan perintah SELECT diikuti oleh MIN, MAX, atau AVERAGE, untuk lebih
jelasnya kita lihat contoh :
Mencari nilai MINIMAL è MIN
mysql> select MIN(gaji) from pegawai;
+-----------+
|
MIN(gaji) |
+-----------+
| 500000 |
+-----------+
1 row in set (1.05 sec)
Mencari nilai MAKSIMAL è MAX
mysql> select MAX(gaji) from pegawai;
+-----------+
|
MAX(gaji) |
+-----------+
| 9000000 |
+-----------+
1 row in set (0.00 sec)
Mencari nilai RATA - RATA è AVG
mysql> select AVG(gaji) from pegawai;
+--------------+
|
AVG(gaji) |
+--------------+
|
3766666.6667 |
+--------------+
1 row in set (0.41 sec)
Menghitung Nilai Total è SUM
mysql> select SUM(gaji) from pegawai;
+-----------+
|
SUM(gaji) |
+-----------+
| 56500000 |
+-----------+
1 row in set (0.39 sec)
SUB QUERY
Sub
Query adalah penggunaan statement SELECT di dalam statement SELECT, Sub Query
dideklarasikan di dalam perintah my qsl di dalam tanda ( ), dan biasa
menggunakan salah satu dari statemen SELECT, UPDATE, SET, DELETE, atau DO
CONTOH :
mysql> select nama_peg, gaji from pegawai
where gaji = (select max(gaji) from pe
gawai);
+-----------------------+---------+
| nama_peg | gaji |
+-----------------------+---------+
| Soeharto Mangundirejo |
9000000 |
+-----------------------+---------+
1 row in
set (0.06 sec)
Perintah
ini hanya bisa menerima satu(1) buah hasil dari sub query, jika hasil dari sub
query ada lebih adari satu maka akan terjadi error.
mysql> select nama_peg, gaji from pegawai
where alamat_peg = (select alamat_peg from pegawai where alamat_peg LIKE 'J%');
ERROR
1242 (21000): Subquery returns more than 1 row
Perintah
diatas ini ERROR karena hasil sub query diatas ada lebih dari satu(1)
1.
Sub query dengan ALL
Command ALL
diikuti dengan operator perbandingan digunakan memiliki arti menampilkan nilai
jika perbandingan bernilai benar untuk semua data. Berikut adalah contoh
penggunaannya.
mysql> select nama_peg, gaji from
pegawai where gaji < ALL(select gaji FROM pegawai WHERE gaji >
'2500000');
+----------------+---------+
| nama_peg | gaji
|
+----------------+---------+
| Rano Karno | 2000000 |
| Rahmadi Sholeh | 2000000 |
| Ilham Ungara | 2000000 |
| Endang Melati | 2000000 |
| Donny Damara | 1000000 |
| Paijem |
500000 |
+----------------+---------+
6 rows in set
(0.00 sec)
Contoh
diatas menunjukkan penampilan atas nama pegawai beserta gajinya yang memiliki
gaji kurang dari 2,5jt
2.
Sub query dengan ANY
Command
ANY diikuti dengan operator perbandingan memiliki arti menampilkan nilai yang
sesuai dengan apapun yang dihasilkan oleh sub query. Alias dari ANY adalah SOME. Berikut
adalah contohnya:
mysql> select nama_peg, gaji from pegawai
where gaji < ANY(select gaji FROM pega
wai WHERE gaji > '2000000');
+-------------------+---------+
| nama_peg | gaji
|
+-------------------+---------+
| Felix Nababan | 8000000 |
| Olga Syahputra | 6000000 |
| Chelsea Olivia | 6000000 |
| Tuti Wardani | 4500000 |
| Budi Drajat | 4500000 |
| Bambang Pamungkas |
3000000 |
| Ely Oktafiani | 3000000 |
| Rani Wijaya | 3000000 |
| Rano Karno | 2000000 |
| Rahmadi Sholeh | 2000000 |
| Ilham Ungara | 2000000 |
| Endang Melati | 2000000 |
| Donny Damara | 1000000 |
| Paijem |
500000 |
+-------------------+---------+
14 rows
in set (0.00 sec)
Pada
perintah diatas kita perhatikan perintah select yang berada di dalam kurung
(Sub Query), pada perintah itu menjelaskan bahwa penampilan daftar nama pegawai
yang gajinya lebih dari 2jt, sedangkan Quert seutuhnya menampilkan nama pegawai
yang gajinya lebih kecil daripada hasil sub query, Soeharto Mangundirejo tidak
keluar di hasil karena tidak ada yang mempunyai gaji sebesar dirinya.
mysql> select nama_peg, gaji from pegawai
where gaji < SOME(select gaji FROM peg
awai WHERE gaji > '2000000');
+-------------------+---------+
| nama_peg | gaji |
+-------------------+---------+
| Felix Nababan | 8000000 |
| Olga Syahputra | 6000000 |
| Chelsea Olivia | 6000000 |
| Tuti Wardani | 4500000 |
| Budi Drajat | 4500000 |
| Bambang Pamungkas |
3000000 |
| Ely Oktafiani | 3000000 |
| Rani Wijaya | 3000000 |
| Rano Karno | 2000000 |
| Rahmadi Sholeh | 2000000 |
| Ilham Ungara | 2000000 |
| Endang Melati | 2000000 |
| Donny Damara | 1000000 |
| Paijem |
500000 |
+-------------------+---------+
14 rows
in set (0.45 sec)
3.
Sub query dengan EXISTS
Perintah
EXISTS disini berguna untuk mengartur penampilan hasil query, Query Utama akan
dijalankan jika Sub Query bernilai TRUE (ada hasilnya) jika hasilnya kosong
maka Query utama tidak akan dijalankan. Lawan dari statement EXISTS adalah NOT
EXISTS
mysql> select * from pegawai where EXISTS
(select * from pegawai where alamat_pe
g = 'Yogyakarta');
+----------+-----------------------+-------------+----------------+---------+
| nip | nama_peg | alamat_peg | jabatan | gaji |
+----------+-----------------------+-------------+----------------+---------+
| PEG-1001 | Soeharto Mangundirejo
| Yogyakarta | C.E.O | 9000000 |
| PEG-1002 | Felix
Nababan | Medan | Manager | 8000000 |
| PEG-1003 | Olga
Syahputra | Jakarta | Kepala Unit | 6000000 |
| PEG-1004 | Chelsea
Olivia | Bandung |
Kepala Unit | 6000000 |
| PEG-1005 | Tuti
Wardani | Jawa Tengah |
Supervisor | 4500000 |
| PEG-1006 | Budi
Drajat | Malang | Supervisor | 4500000 |
| PEG-1007 | Bambang
Pamungkas | Kudus | Staff Senior | 3000000 |
| PEG-1008 | Ely
Oktafiani | Yogyakarta | Staff Senior | 3000000 |
| PEG-1009 | Rani
Wijaya | Magelang | Staff Senior | 3000000 |
| PEG-1010 | Rano
Karno | Solo | Staff Junior | 2000000 |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta | Staff Junior | 2000000 |
| PEG-1012 | Ilham
Ungara | Jakarta | Staff Junior | 2000000 |
| PEG-1013 | Endang
Melati | Madiun | Staff Junior | 2000000 |
| PEG-1014 | Donny
Damara | Makasar | Tenaga Kontrak | 1000000 |
| PEG-1015 | Paijem | Yogyakarta | Tenaga Kontrak | 500000 |
+----------+-----------------------+-------------+----------------+---------+
15 rows
in set (0.00 sec)
Dari
perintah diatas menunjukkan bahwa Query utama dieksesusi karena Sub Query
bernilai TRUE atau ada hasilnya
mysql> select * from pegawai where EXISTS
(select * from pegawai where alamat_pe
g = 'Kebumen');
Empty
set (0.00 sec)
Sedangkan
perintah ini tidak dijalankan karena Sub Query bernilai FALSE atau tidak ada
hasilnya.
Jika
kita ganti EXISTS dengan NOT EXISTS maka hasil akan keluar seperti di bawah
ini, karena memang alamat-peg tidak ada yang bernilai ‘Kebumen’
mysql> select * from pegawai where NOT
EXISTS (select * from pegawai where alama
t_peg = 'Kebumen');
+----------+-----------------------+-------------+----------------+---------+
| nip | nama_peg | alamat_peg | jabatan | gaji |
+----------+-----------------------+-------------+----------------+---------+
| PEG-1001 | Soeharto
Mangundirejo | Yogyakarta | C.E.O | 9000000 |
| PEG-1002 | Felix
Nababan | Medan | Manager | 8000000 |
| PEG-1003 | Olga
Syahputra | Jakarta
| Kepala Unit | 6000000 |
| PEG-1004 | Chelsea
Olivia | Bandung | Kepala Unit | 6000000 |
| PEG-1005 | Tuti
Wardani | Jawa Tengah |
Supervisor | 4500000 |
| PEG-1006 | Budi
Drajat | Malang | Supervisor | 4500000 |
| PEG-1007 | Bambang
Pamungkas | Kudus | Staff Senior | 3000000 |
| PEG-1008 | Ely
Oktafiani | Yogyakarta | Staff Senior | 3000000 |
| PEG-1009 | Rani
Wijaya | Magelang | Staff Senior | 3000000 |
| PEG-1010 | Rano
Karno | Solo | Staff Junior | 2000000 |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta | Staff Junior | 2000000 |
| PEG-1012 | Ilham
Ungara | Jakarta | Staff Junior | 2000000 |
| PEG-1013 | Endang Melati | Madiun | Staff Junior | 2000000 |
| PEG-1014 | Donny
Damara | Makasar | Tenaga Kontrak | 1000000 |
| PEG-1015 | Paijem | Yogyakarta | Tenaga Kontrak | 500000 |
+----------+-----------------------+-------------+----------------+---------+
15 rows
in set (0.00 sec)
4.
Sub query dengan IN
Jika
operator ‘=’ hanya digunakan untuk hasil yang tepat satu, maka jika ingin
menampilkan yang memiliki hasil lebih dari satu maka menggunakan perintah IN,
berikut contohnya :
Kita
buat terlebih dahulu sebuah tabel yang menunjukkan hasil yang kita inginkan,
contoh tabel Job ini digunakan untuk menampilkan data yang hasil dari sub query
lebih dari satu.
mysql>
create table job( id int(2) primary key, job varchar(20));
Query
OK, 0 rows affected (0.52 sec)
mysql>
desc job;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id | int(2) | NO
| PRI | NULL | |
| job | varchar(20) | YES | |
NULL | |
+-------+-------------+------+-----+---------+-------+
2 rows
in set (0.17 sec)
mysql>
select*from job;
+----+----------------+
| id | job |
+----+----------------+
| 1 | Supervisor |
| 2 | Staff Senior |
| 3 | Staff Junior |
| 4 | Tenaga Kontrak |
+----+----------------+
4 rows
in set (0.00 sec)
Setelah
kita buat table job, maka kita bisa terapkan perintah IN sbb :
mysql> select nip, nama_peg, jabatan from
pegawai where jabatan IN (select job f
rom job);
+----------+-------------------+----------------+
| nip | nama_peg | jabatan |
+----------+-------------------+----------------+
| PEG-1005 | Tuti
Wardani | Supervisor |
| PEG-1006 | Budi
Drajat | Supervisor |
| PEG-1007 | Bambang
Pamungkas | Staff Senior |
| PEG-1008 | Ely
Oktafiani | Staff Senior |
| PEG-1009 | Rani
Wijaya | Staff Senior |
| PEG-1010 | Rano
Karno | Staff Junior |
| PEG-1011 | Rahmadi
Sholeh | Staff Junior |
| PEG-1012 | Ilham
Ungara | Staff Junior |
| PEG-1013 | Endang
Melati | Staff Junior |
| PEG-1014 | Donny
Damara | Tenaga Kontrak |
| PEG-1015 | Paijem | Tenaga Kontrak |
+----------+-------------------+----------------+
11 rows
in set (0.00 sec)
Terlihat
di dalam hasil bahwa, data pegawai yang jabatannya ada di dalam tabel job akan
ditampilkan, sedangkan yang tidak ada tidak akan ditampilkan.
Table Join
Dalam basis data relasional, kita mengenal
relasi antar tabel. Untuk melakukan query terhadap dua atau lebih tabel yang
memiliki relasi, kita bisa menggunakan fitur table join di MySQL.
Sebelum kita mulai mempelajari Table Join
kita persiapkan dulu Tabel-tabel pendukungnya :
mysql> desc jabatan;
+------------+-------------+------+-----+---------+-------+
|
Field | Type | Null | Key | Default | Extra |
+------------+-------------+------+-----+---------+-------+
|
id_jabatan | int(2) | NO | PRI | NULL |
|
|
nm_jabatan | varchar(20) | YES | | NULL
| |
+------------+-------------+------+-----+---------+-------+
2 rows in set (0.22 sec)
mysql> select * from jabatan;
+------------+----------------+
|
id_jabatan | nm_jabatan |
+------------+----------------+
| 1 | C.E.O |
| 2 | Manager |
| 3 | kepala Unit |
| 4 | Supervisor |
| 5 | Staff Senior |
| 6 | Staff Junior |
| 7 | Tenaga Kontrak |
+------------+----------------+
7 rows in set (0.00 sec)
Setelah kita punya table jabatan / job,
kita buat tabel baru untuk menerapkan join, kita copykan table pegawai ke tabel
pegawai_join
mysql> create table pegawai_join AS
(select*from pegawai);
Query OK, 15 rows affected (0.45 sec)
Records: 15
Duplicates: 0 Warnings: 0
mysql> select * from pegawai_join;
+----------+-----------------------+-------------+----------------+---------+
|
nip | nama_peg | alamat_peg | jabatan | gaji |
+----------+-----------------------+-------------+----------------+---------+
|
PEG-1001 | Soeharto Mangundirejo | Yogyakarta
| C.E.O | 9000000 |
|
PEG-1002 | Felix Nababan |
Medan | Manager | 8000000 |
|
PEG-1003 | Olga Syahputra |
Jakarta | Kepala Unit | 6000000 |
|
PEG-1004 | Chelsea Olivia |
Bandung | Kepala Unit | 6000000 |
|
PEG-1005 | Tuti Wardani | Jawa
Tengah | Supervisor | 4500000 |
|
PEG-1006 | Budi Drajat | Malang | Supervisor | 4500000 |
|
PEG-1007 | Bambang Pamungkas |
Kudus | Staff Senior | 3000000 |
|
PEG-1008 | Ely Oktafiani |
Yogyakarta | Staff Senior | 3000000 |
|
PEG-1009 | Rani Wijaya |
Magelang | Staff Senior | 3000000 |
|
PEG-1010 | Rano Karno |
Solo | Staff Junior | 2000000 |
|
PEG-1011 | Rahmadi Sholeh |
Yogyakarta | Staff Junior | 2000000 |
|
PEG-1012 | Ilham Ungara |
Jakarta | Staff Junior | 2000000 |
|
PEG-1013 | Endang Melati |
Madiun | Staff Junior | 2000000 |
|
PEG-1014 | Donny Damara |
Makasar | Tenaga Kontrak | 1000000 |
|
PEG-1015 | Paijem |
Yogyakarta | Tenaga Kontrak | 500000 |
+----------+-----------------------+-------------+----------------+---------+
15 rows in set (0.00 sec)
Untuk merelasikan table pegawai_join dan
table jabatan kita tambahkan kolom id_jabatan pada table pegawai_join untuk
mereferensi ke dua table.
mysql>
alter table pegawai_join ADD id_jabatan int(2) AFTER alamat_peg;
Query OK, 15 rows affected (0.20 sec)
Records: 15
Duplicates: 0 Warnings: 0
mysql>
desc pegawai_join;
+------------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+------------+-------------+------+-----+---------+-------+
| nip | varchar(8) | NO
| | NULL |
|
| nama_peg | varchar(50) | YES | |
NULL | |
| alamat_peg | varchar(50) | YES | |
NULL | |
| id_jabatan | int(2) | YES
| | NULL |
|
| jabatan | varchar(20) | YES | |
NULL | |
| gaji | int(7) | YES
| | NULL |
|
+------------+-------------+------+-----+---------+-------+
6 rows in
set (0.00 sec)
Jika kita
lihat isi tablenya kolom id_jabatan masih NULL atau kosong karena ke dua table
belum berelasi
mysql>
select * from pegawai_join;
+----------+-----------------------+-------------+------------+----------------+---------+
|
nip | nama_peg | alamat_peg | id_jabatan | jabatan | gaji |
+----------+-----------------------+-------------+------------+----------------+---------+
|
PEG-1001 | Soeharto Mangundirejo | Yogyakarta
| NULL | C.E.O | 9000000 |
|
PEG-1002 | Felix Nababan |
Medan | NULL | Manager | 8000000 |
|
PEG-1003 | Olga Syahputra |
Jakarta | NULL | Kepala Unit | 6000000 |
|
PEG-1004 | Chelsea Olivia |
Bandung | NULL | Kepala Unit | 6000000 |
|
PEG-1005 | Tuti Wardani | Jawa
Tengah | NULL | Supervisor | 4500000 |
|
PEG-1006 | Budi Drajat |
Malang | NULL | Supervisor | 4500000 |
|
PEG-1007 | Bambang Pamungkas |
Kudus | NULL | Staff Senior | 3000000 |
|
PEG-1008 | Ely Oktafiani |
Yogyakarta | NULL | Staff Senior | 3000000 |
|
PEG-1009 | Rani Wijaya |
Magelang | NULL | Staff Senior | 3000000 |
|
PEG-1010 | Rano Karno |
Solo |
NULL | Staff Junior | 2000000 |
|
PEG-1011 | Rahmadi Sholeh |
Yogyakarta | NULL | Staff Junior | 2000000 |
|
PEG-1012 | Ilham Ungara |
Jakarta | NULL | Staff Junior | 2000000 |
|
PEG-1013 | Endang Melati | Madiun |
NULL | Staff Junior | 2000000 |
|
PEG-1014 | Donny Damara |
Makasar | NULL | Tenaga Kontrak | 1000000 |
|
PEG-1015 | Paijem |
Yogyakarta | NULL | Tenaga Kontrak | 500000 |
+----------+-----------------------+-------------+------------+----------------+---------+
15 rows in
set (0.00 sec)
Agar data
di kolom bisa masuk maka kita relasikan sbb:
Kita
gunakan UPDATE untuk mengubah diskripsi dari kolom id_jabatan di table pegawai
UPDATE <nama_table1> ,
<nama_table2> SET <nama_table1.nama_kolom> = <nama_table1.
nama_kolom2> WHERE //data yang sama// <nama_table1.nama_kolom1> =
<nama_table2.nama_kolom2>
mysql> UPDATE pegawai_join,
jabatan SET pegawai_join.id_jabatan = jabatan.id_jabatan WHERE pegawai_join.jabatan=jabatan.nm_jabatan;
Query OK,
15 rows affected (0.48 sec)
Rows
matched: 15 Changed: 15 Warnings: 0
mysql>
select * from pegawai_join;
+----------+-----------------------+-------------+------------+----------------+---------+
|
nip | nama_peg | alamat_peg | id_jabatan | jabatan | gaji |
+----------+-----------------------+-------------+------------+----------------+---------+
|
PEG-1001 | Soeharto Mangundirejo | Yogyakarta
| 1 | C.E.O | 9000000 |
|
PEG-1002 | Felix Nababan |
Medan | 2 | Manager | 8000000 |
|
PEG-1003 | Olga Syahputra |
Jakarta | 3 | Kepala Unit | 6000000 |
|
PEG-1004 | Chelsea Olivia |
Bandung | 3 | Kepala Unit | 6000000 |
|
PEG-1005 | Tuti Wardani | Jawa
Tengah | 4 | Supervisor | 4500000 |
|
PEG-1006 | Budi Drajat |
Malang | 4 | Supervisor | 4500000 |
|
PEG-1007 | Bambang Pamungkas |
Kudus |
5 | Staff Senior | 3000000 |
|
PEG-1008 | Ely Oktafiani |
Yogyakarta | 5 | Staff Senior | 3000000 |
|
PEG-1009 | Rani Wijaya |
Magelang | 5 | Staff Senior | 3000000 |
|
PEG-1010 | Rano Karno | Solo | 6 | Staff Junior | 2000000 |
|
PEG-1011 | Rahmadi Sholeh |
Yogyakarta | 6 | Staff Junior | 2000000 |
|
PEG-1012 | Ilham Ungara |
Jakarta | 6 | Staff Junior | 2000000 |
|
PEG-1013 | Endang Melati |
Madiun | 6 | Staff Junior | 2000000 |
|
PEG-1014 | Donny Damara |
Makasar | 7 | Tenaga Kontrak | 1000000 |
|
PEG-1015 | Paijem |
Yogyakarta | 7 | Tenaga Kontrak | 500000 |
+----------+-----------------------+-------------+------------+----------------+---------+
15 rows in
set (0.00 sec)
1. Cross
Join
Operasi tabel yang pertama adalah cross
join atau disebut juga sebagai Cartesian join. Pada cross join, semua data dalam tabel yang pertama
dipasangkan dengan semua data pada tabel yang kedua. Berikut adalah contohnya
SYNTAX
DASAR
SELECT * FROM <nama_tabel1>,
<nama_tabel2>;
mysql>
select * from pegawai_join, jabatan;
mysql> select * from
pegawai_join, jabatan;
+----------+-----------------------+-------------+------------+----------------+---------+------------+----------------+
| nip | nama_peg | alamat_peg | id_jabatan | jabatan | gaji | id_jabatan | nama_jabatan |
+----------+-----------------------+-------------+------------+----------------+---------+------------+----------------+
| PEG-1001 | Soeharto
Mangundirejo | Yogyakarta | 1 | C.E.O | 9000000 |1 | C.E.O |
| PEG-1001 | Soeharto
Mangundirejo | Yogyakarta | 1 | C.E.O | 9000000 |2 | Manager |
| PEG-1001 | Soeharto
Mangundirejo | Yogyakarta | 1 | C.E.O | 9000000 |3 | Kepala Unit |
| PEG-1001 | Soeharto
Mangundirejo | Yogyakarta | 1 | C.E.O | 9000000 |4 | Supervisor |
| PEG-1001 | Soeharto
Mangundirejo | Yogyakarta | 1 | C.E.O | 9000000 |5 | Staff Senior |
| PEG-1001 | Soeharto
Mangundirejo | Yogyakarta | 1 | C.E.O | 9000000 |6 | Staff Junior |
| PEG-1001 | Soeharto
Mangundirejo | Yogyakarta | 1 | C.E.O | 9000000 |7 | Tenaga Kontrak |
| PEG-1002 | Felix
Nababan | Medan | 2 | Manager | 8000000 |1 | C.E.O |
| PEG-1002 | Felix
Nababan | Medan | 2 | Manager | 8000000 |2 | Manager |
| PEG-1002 | Felix
Nababan | Medan | 2 | Manager | 8000000 |3 | Kepala Unit |
| PEG-1002 | Felix
Nababan | Medan | 2 | Manager | 8000000 |4 | Supervisor |
| PEG-1002 | Felix
Nababan | Medan | 2 | Manager | 8000000 |5 | Staff Senior |
| PEG-1002 | Felix
Nababan | Medan
| 2 | Manager | 8000000 |6 | Staff Junior |
| PEG-1002 | Felix
Nababan | Medan | 2 | Manager | 8000000 |7 | Tenaga Kontrak |
| PEG-1003 | Olga
Syahputra | Jakarta |
3 | Kepala Unit | 6000000 |1 | C.E.O |
| PEG-1003 | Olga
Syahputra | Jakarta |
3 | Kepala Unit | 6000000 |2 | Manager |
| PEG-1003 | Olga
Syahputra | Jakarta |
3 | Kepala Unit | 6000000 |3 | Kepala Unit |
| PEG-1003 | Olga
Syahputra | Jakarta |
3 | Kepala Unit | 6000000 |4 | Supervisor |
| PEG-1003 | Olga
Syahputra | Jakarta |
3 | Kepala Unit | 6000000 |5 | Staff Senior |
| PEG-1003 | Olga
Syahputra | Jakarta |
3 | Kepala Unit | 6000000 |6 | Staff Junior |
| PEG-1003 | Olga
Syahputra | Jakarta |
3 | Kepala Unit | 6000000 |7 | Tenaga Kontrak |
| PEG-1004 | Chelsea
Olivia | Bandung |
3 | Kepala Unit | 6000000 |1 | C.E.O |
| PEG-1004 | Chelsea
Olivia | Bandung |
3 | Kepala Unit | 6000000 |2 | Manager |
| PEG-1004 | Chelsea
Olivia | Bandung |
3 | Kepala Unit | 6000000 |3 | Kepala Unit |
| PEG-1004 | Chelsea
Olivia | Bandung |
3 | Kepala Unit | 6000000 |4 | Supervisor |
| PEG-1004 | Chelsea
Olivia | Bandung |
3 | Kepala Unit | 6000000 |5 | Staff Senior |
| PEG-1004 | Chelsea
Olivia | Bandung |
3 | Kepala Unit | 6000000 |6 | Staff Junior |
| PEG-1004 | Chelsea
Olivia | Bandung |
3 | Kepala Unit | 6000000 |7 | Tenaga Kontrak |
| PEG-1005 | Tuti
Wardani | Jawa Tengah | 4 | Supervisor | 4500000 |1 | C.E.O |
| PEG-1005 | Tuti
Wardani | Jawa Tengah | 4 | Supervisor | 4500000 |2 | Manager |
| PEG-1005 | Tuti
Wardani | Jawa Tengah | 4 | Supervisor | 4500000 |3 | Kepala Unit |
| PEG-1005 | Tuti
Wardani | Jawa Tengah | 4 | Supervisor | 4500000 |4 | Supervisor |
| PEG-1005 | Tuti
Wardani | Jawa Tengah | 4 | Supervisor | 4500000 |5 | Staff Senior |
| PEG-1005 | Tuti
Wardani | Jawa Tengah | 4 | Supervisor | 4500000 |6 | Staff Junior |
| PEG-1005 | Tuti
Wardani | Jawa Tengah | 4 | Supervisor | 4500000 |7 | Tenaga Kontrak |
| PEG-1006 | Budi
Drajat | Malang |
4 | Supervisor | 4500000 |1 | C.E.O |
| PEG-1006 | Budi
Drajat | Malang |
4 | Supervisor | 4500000 |2 | Manager |
| PEG-1006 | Budi
Drajat | Malang |
4 | Supervisor | 4500000 |3 | Kepala Unit |
| PEG-1006 | Budi
Drajat | Malang |
4 | Supervisor | 4500000 |4 | Supervisor |
| PEG-1006 | Budi
Drajat | Malang
| 4 | Supervisor | 4500000 |5 | Staff Senior |
| PEG-1006 | Budi
Drajat | Malang |
4 | Supervisor | 4500000 |6 | Staff Junior |
| PEG-1006 | Budi
Drajat | Malang |
4 | Supervisor | 4500000 |7 | Tenaga Kontrak |
| PEG-1007 | Bambang
Pamungkas | Kudus | 5 | Staff Senior | 3000000 |1 | C.E.O |
| PEG-1007 | Bambang
Pamungkas | Kudus | 5 | Staff Senior | 3000000 |2 | Manager |
| PEG-1007 | Bambang
Pamungkas | Kudus | 5 | Staff Senior | 3000000 |3 | Kepala Unit |
| PEG-1007 | Bambang
Pamungkas | Kudus | 5 | Staff Senior | 3000000 |4 | Supervisor |
| PEG-1007 | Bambang
Pamungkas | Kudus | 5 | Staff Senior | 3000000 |5 | Staff Senior |
| PEG-1007 | Bambang
Pamungkas | Kudus | 5 | Staff Senior | 3000000 |6 | Staff Junior |
| PEG-1007 | Bambang
Pamungkas | Kudus
| 5 | Staff Senior | 3000000 |7 | Tenaga Kontrak |
| PEG-1008 | Ely
Oktafiani | Yogyakarta |
5 | Staff Senior | 3000000 |1 | C.E.O |
| PEG-1008 | Ely
Oktafiani | Yogyakarta |
5 | Staff Senior | 3000000 |2 | Manager |
| PEG-1008 | Ely
Oktafiani | Yogyakarta |
5 | Staff Senior | 3000000 |3 | Kepala Unit |
| PEG-1008 | Ely
Oktafiani | Yogyakarta |
5 | Staff Senior | 3000000 |4 | Supervisor |
| PEG-1008 | Ely
Oktafiani | Yogyakarta |
5 | Staff Senior | 3000000 |5 | Staff Senior |
| PEG-1008 | Ely
Oktafiani | Yogyakarta |
5 | Staff Senior | 3000000 |6 | Tenaga Kontrak |
| PEG-1009 | Rani
Wijaya | Magelang |
5 | Staff Senior | 3000000 |1 | C.E.O |
| PEG-1009 | Rani
Wijaya | Magelang |
5 | Staff Senior | 3000000 |2 | Manager |
| PEG-1009 | Rani
Wijaya | Magelang |
5 | Staff Senior | 3000000 |3 | Kepala Unit |
| PEG-1009 | Rani
Wijaya | Magelang |
5 | Staff Senior | 3000000 |4 | Supervisor |
| PEG-1009 | Rani
Wijaya | Magelang |
5 | Staff Senior | 3000000 |5 | Staff Senior |
| PEG-1009 | Rani
Wijaya | Magelang |
5 | Staff Senior | 3000000 |6 | Staff Junior |
| PEG-1009 | Rani
Wijaya | Magelang |
5 | Staff Senior | 3000000 |7 | Tenaga Kontrak |
| PEG-1010 | Rano
Karno | Solo | 6 | Staff Junior | 2000000 |1 | C.E.O |
| PEG-1010 | Rano
Karno | Solo | 6 | Staff Junior | 2000000 |2 | Manager |
| PEG-1010 | Rano
Karno | Solo | 6 | Staff Junior | 2000000 |3 | Kepala Unit |
| PEG-1010 | Rano
Karno | Solo | 6 | Staff Junior | 2000000 |4 | Supervisor |
| PEG-1010 | Rano
Karno | Solo
| 6 | Staff Junior | 2000000 |5 | Staff Senior |
| PEG-1010 | Rano
Karno | Solo | 6 | Staff Junior | 2000000 |6 | Staff Junior |
| PEG-1010 | Rano
Karno | Solo | 6 | Staff Junior | 2000000 |7 | Tenaga Kontrak |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta |
6 | Staff Junior | 2000000 |1 | C.E.O |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta |
6 | Staff Junior | 2000000 |2 | Manager |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta |
6 | Staff Junior | 2000000 |3 | Kepala Unit |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta |
6 | Staff Junior | 2000000 |4 | Supervisor |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta |
6 | Staff Junior | 2000000 |5 | Staff Senior |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta |
6 | Staff Junior | 2000000 |6 | Staff Junior |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta |
6 | Staff Junior | 2000000 |7 | Tenaga Kontrak |
| PEG-1012 | Ilham
Ungara | Jakarta |
6 | Staff Junior | 2000000 |1 | C.E.O |
| PEG-1012 | Ilham
Ungara | Jakarta |
6 | Staff Junior | 2000000 |2 | Manager |
| PEG-1012 | Ilham
Ungara | Jakarta |
6 | Staff Junior | 2000000 |3 | Kepala Unit |
| PEG-1012 | Ilham
Ungara | Jakarta |
6 | Staff Junior | 2000000 |4 | Supervisor |
| PEG-1012 | Ilham
Ungara | Jakarta |
6 | Staff Junior | 2000000 |5 | Staff Senior |
| PEG-1012 | Ilham
Ungara | Jakarta |
6 | Staff Junior | 2000000 |6 | Staff Junior |
| PEG-1012 | Ilham
Ungara | Jakarta
| 6 | Staff Junior | 2000000 |7 | Tenaga Kontrak |
| PEG-1013 | Endang
Melati | Madiun |
6 | Staff Junior | 2000000 |1 | C.E.O |
| PEG-1013 | Endang
Melati | Madiun |
6 | Staff Junior | 2000000 |2 | Manager |
| PEG-1013 | Endang
Melati | Madiun |
6 | Staff Junior | 2000000 |3 | Kepala Unit |
| PEG-1013 | Endang
Melati | Madiun |
6 | Staff Junior | 2000000 |4 | Supervisor |
| PEG-1013 | Endang
Melati | Madiun |
6 | Staff Junior | 2000000 |5 | Staff Senior |
| PEG-1013 | Endang
Melati | Madiun |
6 | Staff Junior | 2000000 |6 | Staff Junior |
| PEG-1013 | Endang
Melati | Madiun |
6 | Staff Junior | 2000000 |7 | Tenaga Kontrak |
| PEG-1014 | Donny
Damara | Makasar |
7 | Tenaga Kontrak | 1000000 |1 |
C.E.O |
| PEG-1014 | Donny
Damara | Makasar |
7 | Tenaga Kontrak | 1000000 |2 |
Manager |
| PEG-1014 | Donny
Damara | Makasar |
7 | Tenaga Kontrak | 1000000 |3 |
Kepala Unit |
| PEG-1014 | Donny
Damara | Makasar
| 7 | Tenaga Kontrak |
1000000 |4 | Supervisor |
| PEG-1014 | Donny
Damara | Makasar |
7 | Tenaga Kontrak | 1000000 |5 |
Staff Senior |
| PEG-1014 | Donny
Damara | Makasar |
7 | Tenaga Kontrak | 1000000 |6 |
Staff Junior |
| PEG-1014 | Donny
Damara | Makasar |
7 | Tenaga Kontrak | 1000000 |7 |
Tenaga Kontrak |
| PEG-1015 |
Paijem | Yogyakarta |
7 | Tenaga Kontrak | 500000 |1 | C.E.O |
| PEG-1015 |
Paijem | Yogyakarta |
7 | Tenaga Kontrak | 500000 |2 | Manager |
| PEG-1015 |
Paijem | Yogyakarta |
7 | Tenaga Kontrak | 500000 |3 | Kepala Unit |
| PEG-1015 | Paijem | Yogyakarta |
7 | Tenaga Kontrak | 500000 |4 | Supervisor |
| PEG-1015 |
Paijem | Yogyakarta |
7 | Tenaga Kontrak | 500000 |5 | Staff Senior |
| PEG-1015 |
Paijem | Yogyakarta |
7 | Tenaga Kontrak | 500000 |6 | Staff Junior |
| PEG-1015 |
Paijem | Yogyakarta |
7 | Tenaga Kontrak | 500000 |7 | Tenaga Kontrak |
+----------+-----------------------+-------------+------------+----------------+---------+------------+----------------+
105 rows in set (0.00
sec)
Pada Cros Join semua data di table
pegawai akan direlasikan satu persatu dengan data di table jabatan.
Jadi ada 105 baris hasil cross join.
2.
Equi-Join atau Inner Join
Inner
join menggabungkan tabel dengan
membandingkan nilai yang sama antara dua
buah kolom. Kolom yang dibandingkan
dapat kita spesifikasikan.
mysql> SELECT * FROM pegawai, jabatan
WHERE pegawai.jabatan = jabatan. nm_jabatan;
mysql>
SELECT * FROM pegawai, jabatan WHERE pegawai.jabatan=jabatan.nama_jabatan;
+----------+-----------------------+-------------+----------------+---------+------------+----------------+
|
nip | nama_peg | alamat_peg | jabatan | gaji | id_jabatan | nama_jabatan |
+----------+-----------------------+-------------+----------------+---------+------------+----------------+
|
PEG-1001 | Soeharto Mangundirejo | Yogyakarta
| C.E.O | 9000000 | 1 | C.E.O |
|
PEG-1002 | Felix Nababan | Medan | Manager | 8000000 | 2 | Manager |
|
PEG-1003 | Olga Syahputra |
Jakarta | Kepala Unit | 6000000 | 3 | Kepala Unit |
|
PEG-1004 | Chelsea Olivia |
Bandung | Kepala Unit | 6000000 | 3 | Kepala Unit |
|
PEG-1005 | Tuti Wardani | Jawa
Tengah | Supervisor | 4500000 | 4 | Supervisor |
|
PEG-1006 | Budi Drajat |
Malang | Supervisor | 4500000 | 4 | Supervisor |
|
PEG-1007 | Bambang Pamungkas |
Kudus | Staff Senior | 3000000 | 5 | Staff Senior |
|
PEG-1008 | Ely Oktafiani |
Yogyakarta | Staff Senior | 3000000 | 5 | Staff Senior |
|
PEG-1009 | Rani Wijaya |
Magelang | Staff Senior | 3000000 | 5 | Staff Senior |
|
PEG-1010 | Rano Karno |
Solo | Staff Junior | 2000000 | 6 | Staff Junior |
|
PEG-1011 | Rahmadi Sholeh |
Yogyakarta | Staff Junior | 2000000 | 6 | Staff Junior |
|
PEG-1012 | Ilham Ungara |
Jakarta | Staff Junior | 2000000 | 6 | Staff Junior |
|
PEG-1013 | Endang Melati |
Madiun | Staff Junior | 2000000 | 6 | Staff Junior |
|
PEG-1014 | Donny Damara |
Makasar | Tenaga Kontrak | 1000000
| 7 | Tenaga Kontrak |
|
PEG-1015 | Paijem |
Yogyakarta | Tenaga Kontrak | 500000 | 7 | Tenaga Kontrak |
+----------+-----------------------+-------------+----------------+---------+------------+----------------+
15
rows in set (0.01 sec)
Selain Menggunakan WHERE kita juga bisa
menggunakan INNER JOIN.. TO..
Berikut contoh syntaxnya :
mysql>
SELECT * FROM pegawai INNER JOIN jabatan ON pegawai.jabatan = jabatan.nama_jabatan;
+----------+-----------------------+-------------+----------------+---------+------------+----------------+
| nip | nama_peg | alamat_peg | jabatan | gaji | id_jabatan | nama_jabatan |
+----------+-----------------------+-------------+----------------+---------+------------+----------------+
| PEG-1001 | Soeharto
Mangundirejo | Yogyakarta | C.E.O | 9000000 | 1 | C.E.O |
| PEG-1002 | Felix
Nababan | Medan | Manager | 8000000 | 2 | Manager |
| PEG-1003 | Olga
Syahputra | Jakarta | Kepala Unit | 6000000 | 3 | Kepala Unit |
| PEG-1004 | Chelsea
Olivia | Bandung | Kepala Unit | 6000000 | 3 | Kepala Unit |
| PEG-1005 | Tuti
Wardani | Jawa Tengah |
Supervisor | 4500000 | 4 | Supervisor |
| PEG-1006 | Budi
Drajat | Malang | Supervisor | 4500000 | 4 | Supervisor |
| PEG-1007 | Bambang
Pamungkas | Kudus | Staff Senior | 3000000 | 5 | Staff Senior |
| PEG-1008 | Ely
Oktafiani | Yogyakarta | Staff Senior | 3000000 | 5 | Staff Senior |
| PEG-1009 | Rani
Wijaya | Magelang | Staff Senior | 3000000 | 5 | Staff Senior |
| PEG-1010 | Rano
Karno | Solo | Staff Junior | 2000000 | 6 | Staff Junior |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta | Staff Junior | 2000000 | 6 | Staff Junior |
| PEG-1012 | Ilham
Ungara | Jakarta | Staff Junior | 2000000 | 6 | Staff Junior |
| PEG-1013 | Endang
Melati | Madiun | Staff Junior | 2000000 | 6 | Staff Junior |
| PEG-1014 | Donny Damara | Makasar | Tenaga Kontrak | 1000000 | 7 | Tenaga Kontrak |
| PEG-1015 |
Paijem | Yogyakarta | Tenaga Kontrak | 500000 | 7 | Tenaga Kontrak |
+----------+-----------------------+-------------+----------------+---------+------------+----------------+
15 rows in set (0.00 sec)
Kita juga bisa menggunakan INNER JOIN.. USING.. sebagai perintah Join
Berikut contohnya :
mysql>
SELECT * FROM pegawai_join INNER JOIN jabatan using (id_jabatan);
+------------+----------+-----------------------+-------------+----------------+---------+----------------+
| id_jabatan | nip | nama_peg | alamat_peg | jabatan | gaji | nama_jabatan |
+------------+----------+-----------------------+-------------+----------------+---------+----------------+
| 1 | PEG-1001 | Soeharto Mangundirejo
| Yogyakarta | C.E.O | 9000000 | C.E.O |
| 2 | PEG-1002 | Felix Nababan | Medan | Manager | 8000000 | Manager |
| 3 | PEG-1003 | Olga Syahputra | Jakarta | Kepala Unit | 6000000 | Kepala Unit |
| 3 | PEG-1004 | Chelsea Olivia | Bandung | Kepala Unit | 6000000 | Kepala Unit |
| 4 | PEG-1005 | Tuti Wardani | Jawa Tengah | Supervisor | 4500000 | Supervisor |
| 4 | PEG-1006 | Budi Drajat | Malang | Supervisor | 4500000 | Supervisor |
| 5 | PEG-1007 | Bambang Pamungkas | Kudus | Staff Senior | 3000000 | Staff Senior |
| 5 | PEG-1008 | Ely Oktafiani | Yogyakarta | Staff Senior | 3000000 | Staff Senior |
| 5 | PEG-1009 | Rani Wijaya | Magelang | Staff Senior | 3000000 | Staff Senior |
| 6 | PEG-1010 | Rano Karno | Solo | Staff Junior | 2000000 | Staff Junior |
| 6 | PEG-1011 | Rahmadi Sholeh | Yogyakarta | Staff Junior | 2000000 | Staff Junior |
| 6 | PEG-1012 | Ilham Ungara | Jakarta | Staff Junior | 2000000 | Staff Junior |
| 6 | PEG-1013 | Endang Melati | Madiun | Staff Junior | 2000000 | Staff Junior |
| 7 | PEG-1014 | Donny Damara | Makasar | Tenaga Kontrak | 1000000 | Tenaga
Kontrak |
| 7 | PEG-1015 | Paijem | Yogyakarta | Tenaga Kontrak | 500000 | Tenaga Kontrak |
+------------+----------+-----------------------+-------------+----------------+---------+----------------+
15 rows in set (0.00 sec)
3.
Natural Join
Natural
join sebenarnya mirip dengan INNER JOIN.
Namun kita tidak perlu menspesifikasikan kolom mana yang ingin kita
bandingkan. Secara automatis, MySQL akan mencari kolom pada dua buah tabel yang
memiliki nilai yang sama dan membandingkannya. Sebagai contoh, untuk tabel
pegawai_join dan jabatan, yang dibandingkan adalah kolom id_jabatan yang ada di
keduanya.
mysql>
select * from pegawai_join NATURAL JOIN jabatan;
+------------+----------+-----------------------+-------------+----------------+---------+----------------+
| id_jabatan | nip | nama_peg | alamat_peg | jabatan | gaji | nama_jabatan |
+------------+----------+-----------------------+-------------+----------------+---------+----------------+
| 1 | PEG-1001 | Soeharto Mangundirejo
| Yogyakarta | C.E.O | 9000000 | C.E.O |
| 2 | PEG-1002 | Felix Nababan | Medan | Manager | 8000000 | Manager |
| 3 | PEG-1003 | Olga Syahputra | Jakarta | Kepala Unit | 6000000 | Kepala Unit |
| 3 | PEG-1004 | Chelsea Olivia | Bandung | Kepala Unit | 6000000 | Kepala Unit |
| 4 | PEG-1005 | Tuti Wardani | Jawa Tengah | Supervisor | 4500000 | Supervisor |
| 4 | PEG-1006 | Budi Drajat | Malang | Supervisor | 4500000 | Supervisor |
| 5 | PEG-1007 | Bambang Pamungkas | Kudus | Staff Senior | 3000000 | Staff Senior |
| 5 | PEG-1008 | Ely Oktafiani | Yogyakarta | Staff Senior | 3000000 | Staff Senior |
| 5 | PEG-1009 | Rani Wijaya | Magelang | Staff Senior | 3000000 | Staff Senior |
| 6 | PEG-1010 | Rano Karno | Solo | Staff Junior | 2000000 | Staff Junior |
| 6 | PEG-1011 | Rahmadi Sholeh | Yogyakarta | Staff Junior | 2000000 | Staff Junior |
| 6 | PEG-1012 | Ilham Ungara | Jakarta | Staff Junior | 2000000 | Staff Junior |
| 6 | PEG-1013 | Endang Melati | Madiun | Staff Junior | 2000000 | Staff Junior |
| 7 | PEG-1014 | Donny Damara | Makasar | Tenaga Kontrak | 1000000 | Tenaga
Kontrak |
| 7 | PEG-1015 | Paijem | Yogyakarta | Tenaga Kontrak | 500000 | Tenaga Kontrak |
+------------+----------+-----------------------+-------------+----------------+---------+----------------+
15 rows in set (0.00
sec)
4.
Left Join dan Right Join
Left join dan right join digunakan
untuk menghindari data yang hilang karena mungkin ada data yang belum
direferensi oleh tabel yang lain.
Sebagai contoh, kita
tambahkan data di jabatan tapi kita tidak referensikan di tabel
employee_join sebagai berikut:
mysql> insert into jabatan
values (8,'Tenaga Magang');
Query OK, 1 row affected (0.05 sec)
Kemudian jika kita lakukan LEFT JOIN
dengan tabel jobs yang kita sebut terlebih dahulu (atau di sebelah kiri) maka
akan muncul sebagai berikut:
mysql> select * from jabatan t1 LEFT JOIN pegawai_join t2 ON t1.id_jabatan = t2. id_jabatan;
+------------+----------------+----------+-----------------------+-------------+------------+----------------+---------+
| id_jabatan | nama_jabatan | nip
| nama_peg |
alamat_peg | id_jabatan | jabatan | gaji |
+------------+----------------+----------+-----------------------+-------------+------------+----------------+---------+
| 1 | C.E.O | PEG-1001 | Soeharto Mangundirejo |
Yogyakarta | 1 | C.E.O | 9000000 |
| 2 | Manager | PEG-1002 | Felix Nababan | Medan | 2 | Manager | 8000000 |
| 3 | Kepala Unit | PEG-1003 | Olga Syahputra | Jakarta |
3 | Kepala Unit | 6000000 |
| 3 | Kepala Unit | PEG-1004 | Chelsea Olivia | Bandung |
3 | Kepala Unit | 6000000 |
| 4 | Supervisor | PEG-1005 | Tuti Wardani | Jawa Tengah | 4 | Supervisor | 4500000 |
| 4 | Supervisor | PEG-1006 | Budi Drajat | Malang |
4 | Supervisor | 4500000 |
| 5 | Staff Senior | PEG-1007 | Bambang Pamungkas | Kudus | 5 | Staff Senior | 3000000 |
| 5 | Staff Senior | PEG-1008 | Ely Oktafiani | Yogyakarta |
5 | Staff Senior | 3000000 |
| 5 | Staff Senior | PEG-1009 | Rani Wijaya | Magelang |
5 | Staff Senior | 3000000 |
| 6 | Staff Junior | PEG-1010 | Rano Karno | Solo | 6 | Staff Junior | 2000000 |
| 6 | Staff Junior | PEG-1011 | Rahmadi Sholeh | Yogyakarta |
6 | Staff Junior | 2000000 |
| 6 | Staff Junior | PEG-1012 | Ilham Ungara | Jakarta |
6 | Staff Junior | 2000000 |
| 6 | Staff Junior | PEG-1013 | Endang Melati | Madiun |
6 | Staff Junior | 2000000 |
| 7 | Tenaga Kontrak | PEG-1014 | Donny
Damara | Makasar | 7 | Tenaga Kontrak | 1000000 |
| 7 | Tenaga Kontrak | PEG-1015 |
Paijem | Yogyakarta |
7 | Tenaga Kontrak | 500000 |
| 8 | Tenaga Magang | NULL
| NULL | NULL |
NULL | NULL | NULL |
+------------+----------------+----------+-----------------------+-------------+------------+----------------+---------+
16 rows in set (0.00 sec)
Meskipun pada tabel jabatan ada data yang belum direferensi, namun
data tersebut tetap ditampilkan dan diberi nilai NULL untuk nilai di tabel
pegawai_join yang belum diketahui. Hal yang sama juga berlaku untuk RIGHT JOIN,
kali ini dengan tabel jabatan berada di sebelah kanan.
mysql>
select * from pegawai_join t1 RIGHT JOIN jabatan
t2 ON t1.id_jabatan = t2.id_jabatan;
+----------+-----------------------+-------------+------------+----------------+---------+------------+----------------+
| nip | nama_peg | alamat_peg | id_jabatan | jabatan | gaji | id_jabatan | nama_jabatan |
+----------+-----------------------+-------------+------------+----------------+---------+------------+----------------+
| PEG-1001 | Soeharto
Mangundirejo | Yogyakarta | 1 | C.E.O | 9000000 | 1 | C.E.O |
| PEG-1002 | Felix
Nababan | Medan | 2 | Manager | 8000000 | 2 | Manager |
| PEG-1003 | Olga
Syahputra | Jakarta |
3 | Kepala Unit | 6000000 | 3 | Kepala Unit |
| PEG-1004 | Chelsea
Olivia | Bandung |
3 | Kepala Unit | 6000000 | 3 | Kepala Unit |
| PEG-1005 | Tuti
Wardani | Jawa Tengah | 4 | Supervisor | 4500000 | 4 | Supervisor |
| PEG-1006 | Budi
Drajat | Malang |
4 | Supervisor | 4500000 | 4 | Supervisor |
| PEG-1007 | Bambang
Pamungkas | Kudus | 5 | Staff Senior | 3000000 | 5 | Staff Senior |
| PEG-1008 | Ely
Oktafiani | Yogyakarta |
5 | Staff Senior | 3000000
| 5 | Staff Senior |
| PEG-1009 | Rani
Wijaya | Magelang |
5 | Staff Senior | 3000000 | 5 | Staff Senior |
| PEG-1010 | Rano
Karno | Solo | 6 | Staff Junior | 2000000 | 6 | Staff Junior |
| PEG-1011 | Rahmadi
Sholeh | Yogyakarta |
6 | Staff Junior | 2000000 | 6 | Staff Junior |
| PEG-1012 | Ilham
Ungara | Jakarta | 6 | Staff Junior | 2000000 | 6 | Staff Junior |
| PEG-1013 | Endang
Melati | Madiun |
6 | Staff Junior | 2000000 | 6 | Staff Junior |
| PEG-1014 | Donny
Damara | Makasar |
7 | Tenaga Kontrak | 1000000 |
7 | Tenaga Kontrak |
| PEG-1015 |
Paijem | Yogyakarta |
7 | Tenaga Kontrak | 500000 | 7 | Tenaga Kontrak |
| NULL | NULL | NULL |
NULL | NULL | NULL | 8 | Tenaga Magang |
+----------+-----------------------+-------------+------------+----------------+---------+------------+----------------+
16 rows in set (0.02
sec)
5.
Update menggunakan Join Table
Kita juga dapat melakukan update menggunakan
Join table. Bentuk sintaksnya adalah
UPDATE <table1>, <table2> SET <column_name> =
'new_value' WHERE <conditions>
Misal, kita ingin merubah
nama belakang dari employee yang
pekerjaannya Spy menjadi 'Bono'. Kita dapat melakukannya sebagai berikut:
mysql> UPDATE
pegawai_join, jabatan SET nama_peg = 'Soeharto
Mangantelo' WHERE pegawai_join.id_jabatan =
jabatan.id_jabatan AND jabatan.nama_jabatan =
'C.E.O';
Query OK, 1 row affected (0.85 sec)
Rows matched: 1 Changed: 1
Warnings: 0
mysql> SELECT nip, nama_peg, jabatan
FROM pegawai_join INNER JOIN jabatan USING (id_jabatan) LIMIT 3;
+----------+---------------------+-------------+
|
nip | nama_peg | jabatan |
+----------+---------------------+-------------+
|
PEG-1001 | Soeharto Mangantelo | C.E.O
|
|
PEG-1002 | Felix Nababan |
Manager |
|
PEG-1003 | Olga Syahputra | Kepala
Unit |
+----------+---------------------+-------------+
3 rows in set (0.00 sec)
6.
Delete menggunakan join table
Kita
juga dapat menghapus data menggunakan join table sebagai berikut:
mysql>
DELETE pegawai_join FROM pegawai_join, jabatan WHERE pegawai_join.id_jabatan =
jabatan.id_jabatan AND jabatan.nama_jabatan = 'Manager';
Query OK, 1 row affected (0.05 sec)
mysql> SELECT nip, nama_peg, jabatan
FROM pegawai_join INNER JOIN jabatan USING (id_jabatan) LIMIT 3;
+----------+---------------------+-------------+
|
nip | nama_peg | jabatan |
+----------+---------------------+-------------+
|
PEG-1001 | Soeharto Mangantelo | C.E.O
|
|
PEG-1003 | Olga Syahputra | Kepala
Unit |
|
PEG-1004 | Chelsea Olivia | Kepala
Unit |
+----------+---------------------+-------------+
3
rows in set (0.00 sec)
0 comments:
Post a Comment