The words you are searching are inside this book. To get more targeted content, please make full-text search by clicking here.

Buku Teks Asas Sains Komputer Tingkatan 3

Discover the best professional documents and content resources in AnyFlip Document Base.
Search
Published by Zawiah Hasnah Yusoff, 2022-03-21 06:31:20

Buku Teks ASK T3

Buku Teks Asas Sains Komputer Tingkatan 3

Pangkalan Data dan SQL 4.1

Langkah 2 Tetingkap Form Wizard akan dipaparkan. Pilih Simbol dan maksud
jadual MURID dan klik butang >> untuk memilih
semua medan yang ada dalam jadual. Simbol Maksud

1.  Klik butang ini Pindah
untuk memilih
jadual. medan yang

2.  Klik butang ini untuk memilih semua medan yang > diklik kepada
ada dalam jadual. Ini bermaksud, semua atribut ruangan
dalam entiti akan dipaparkan di dalam borang.
medan-medan
Langkah 3 Paparan berikut akan diperhatikan. Klik Next
untuk langkah yang seterusnya. terpilih.

Pindah semua

medan yang

sedia ada

>> dalam jadual
kepada

ruangan

medan-medan

terpilih.

Pindah balik
medan yang
diklik kepada
< ruangan
medan-medan
telah sedia
ada.

Pindah balik
semua medan
kepada
<< ruangan
medan-medan
telah sedia
ada.

Semua medan yang 4.9
dipilih akan tertera
dalam ruangan Pada pendapat anda,
Selected Fields. mengapakah adakala
medan-medan daripada
Klik Next. dua jadual yang berlainan
tidak digabungkan untuk
menghasilkan borang?

141

Langkah 4 Klik butang radio Columnar untuk memilih susun
atur Columnar. Kemudian, klik Next.

Jenis susun Maksud
atur

Columnar Rekod
dipaparkan
satu demi 1. Pilih Columnar.
satu.
2. Klik Next.
Tabular Semua
Datasheet rekod Langkah 5 Paparan berikut akan diperhatikan. Namakan
Justified dipaparkan borang anda sebagai BORANG MURID dengan
dalam menaip pada ruangan yang disediakan. Kemudian,
bentuk klik Finish.
jadual yang
menarik.

Semua
rekod
dipaparkan
dalam
bentuk
helaian data
yang agak
menarik.

Semua
medan
(fields)
disusun
pada
baris-baris
blok yang
mempunyai
margin kiri
dan kanan
yang tetap.

1.  Taip nama
borang.

Susun atur columnar 2. Klik Finish.
goo.gl/ZTf1mk

Rajah 4.25  Langkah-langkah membina BORANG MURID daripada
jadual MURID

142

Pangkalan Data dan SQL 4.1

BORANG MURID yang telah berjaya dihasilkan akan 4.10
dipaparkan pada ruangan All Access Objects. Bilangan rekod yang
ditunjukkan adalah sama dengan bilangan rekod yang ada dalam Berikan kelebihan-
jadual MURID. Rajah 4.26 menunjukkan paparan BORANG kelebihan susun atur
MURID. columnar berbanding
susun atur yang lain.

BORANG Nama borang tidak
MURID yang semestinya sama
dihasilkan. dengan nama jadual.
Anda boleh meletakkan
Menunjukkan sebarang nama yang
bilangan rekod sesuai.
yang ada di dalam
jadual MURID. Mengubah suai
reka bentuk borang
Rajah 4.26  Paparan BORANG MURID
Jadual 4.5 menunjukkan penerangan kepada butang-butang goo.gl/DgbrRp
yang terdapat pada bahagian bawah borang.
Jadual 4.5  Penerangan butang-butang yang terdapat pada bahagian 4.11

bawah borang Bagaimanakah cara
untuk menghapuskan
Butang Maksud rekod yang tidak
diperlukan lagi?
Alih kepada rekod yang pertama.

Alih kepada rekod yang sebelumnya.

Alih kepada rekod yang berikutnya.

Alih kepada rekod yang terakhir.

Wujudkan satu rekod yang baharu.

Carian rekod.

143

Selain membina borang daripada satu jadual, borang juga boleh dibina dengan
memilih atribut-atribut daripada dua jadual yang berhubungan. Rajah 4.27 menunjukkan
langkah-langkah membina borang daripada jadual MURID dan jadual MARKAH.
Langkah 1 Buka pangkalan data TUGASAN1. Pada menu bar, klik pada tab Create.

Kemudian, klik Form Wizard.
Langkah 2 Tetingkap Form Wizard akan dipaparkan. Pilih jadual MURID dan klik butang

>> untuk memilih semua medan yang ada dalam jadual. Kemudian, pilih jadual
MARKAH dan klik butang >>.

2.  Pilih jadual MARKAH.

1. S emua medan dalam
jadual MURID dipilih.

3. K lik butang >> untuk pilih semua 4.  Klik Next.
medan dalam MARKAH.

Langkah 3 Paparan berikut akan diperhatikan. Pilih Form with subform(s). Kemudian,
klik Next.

1.  Pilih Form with subform(s). 2.  Klik Next.
Pilihan ini akan membentuk dua
borang yang saling berhubung.

144

Pangkalan Data dan SQL 4.1
Langkah 4 Terdapat dua pilihan susun atur untuk subform iaitu Tabular dan Datasheet. Klik

pada butang radio Datasheet untuk memilih susun atur Datasheet. Kemudian,
klik Next.

1.  Klik butang radio
Datasheet untuk memilih
susun atur Datasheet.

2.  Klik Next.

Langkah 5 Paparan berikut akan diperhatikan. Namakan Borang Murid dan Borang Markah
(Subform). Kemudian, klik Finish.

1.  Namakan Borang Murid dan
Borang Markah (Subform).

2.  Klik Finish.

145

Langkah 6 Borang Murid dan Borang Markah (Subform) telah berjaya dihasilkan. Perhatikan
borang ini memudahkan pengguna memasukkan data untuk dua jadual tanpa
perlu memasukkan ID_Murid iaitu kekunci primer secara berulang.

Rajah 4.27  Langkah-langkah membina borang daripada dua jadual

Jika jenis data Anda berjaya membina borang untuk jadual MURID
(data type) yang dan jadual MARKAH. Kini, anda akan mempelajari langkah-
ditetapkan untuk satu langkah untuk memasukkan data ke dalam jadual-jadual melalui
medan ialah nombor, borang-borang dengan menggunakan fungsi penambahan rekod.
maka nilai lalai yang Rajah 4.28 menunjukkan langkah-langkah menambah rekod
diberikan kepada medan baharu ke dalam jadual MURID dan jadual MARKAH dengan
itu ialah sifar. menggunakan borang yang dibina.

4.12 Langkah 1 Klik ikon di bahagian bawah borang seperti
yang ditunjukkan di bawah.
Namakan objek-objek
pangkalan data yang 2 of 7
telah dihasilkan setakat
ini. Klik ikon ini. Paparan New (blank) record

akan muncul apabila kursor ditunjukkan padanya.

146

Pangkalan Data dan SQL 4.1
Langkah 2 Paparan berikut akan diperhatikan. Kini anda boleh memasukkan data dalam

ruangan kosong. Anda juga boleh memasukkan data untuk dua jadual dalam
satu Borang Murid dan Borang Markah (Subform).

Ruangan kosong
untuk kemasukan
data bagi dua jadual.

Bilangan rekod
bertambah.

Langkah 3 Mula masukkan data murid dan data markah ke dalam ruangan kosong.
Ruangan ID_Murid bagi Borang Markah tidak perlu dimasukkan kerana data
akan dimasukkan secara automatik apabila ID_Murid diisi dalam Borang Murid.
Tekan kekunci Enter pada papan kekunci bagi tujuan memasukkan data yang
seterusnya.

Rajah 4.28  Langkah-langkah untuk menambah rekod baharu ke dalam borang yang dibina
147

Terdapat dua cara untuk memasukkan data ke dalam pangkalan data, iaitu secara
langsung ke dalam jadual atau melalui borang. Anda telah mempelajari kedua-dua cara
tersebut. Rajah 4.29 menunjukkan jadual MURID dan jadual MARKAH yang menunjukkan
bilangan rekod di dalamnya turut bertambah.

MURID Nama_Murid Jantina Kaum Nama_Kelas Nama_Guru_Kelas
DAMIA ZAHRAA BINTI RAHIM PEREMPUAN MELAYU 3 ASERTIF FATIMAH BINTI SEMAN
ID_Murid DHIA ARISSA BINTI MALIK PEREMPUAN MELAYU 3 BIJAK ZAKIAH BINTI YUSOF
+ SM101 DENISH RAIMI BIN ZAINAL MELAYU 3 CEKAL MUSTAFA BIN ROSLAN
+ SM102 LELAKI 3 DINAMIK
+ SM103 TAN XUE LIEH LELAKI CINA 3 EFISIEN TEOH JEE YEE
+ SM104 KUMAR A/L RAMESH LELAKI INDIA 3 FIKIR RIMALA A/P SAMY
+ SM105 JESSICA HENG MUI MUI 3 GIGIH LIM CHOII PENG
+ SM106 PEREMPUAN CINA 3 EFISIEN CHANDRAN A/L SUMAN
+ SM107 KHAIR MUIZ BIN ABD RAHIM LELAKI MELAYU RIMALA A/P SAMY
+ SM108 DEVI A/P MUTHU
PEREMPUAN INDIA

MARKAH ID_Murid BM BI Sn Mate Sej Geo ASK
SM101 45 50 TH 75 45 78 78
ID_Markah SM102 56 85 87 68 84 90 79
PT_SM101 SM103 TH 58 78 65 89 85 79
PT_SM102 SM104
PT_SM103 SM105 67 68 84 TH 77 TH 59
PT_SM104 SM106 77 67 65 87 46 58 58
PT_SM105
PT_SM106 SM107 80 TH 54 76 85 81 85
89 67 80 85 76 68 85
PT_SM107 SM108
PT_SM108 89 67 80 85 76 68 85

Rajah 4.29  Paparan jadual MURID dan jadual MARKAH yang menunjukkan penambahan rekod
dengan menggunakan borang

Penambahan 4.13
rekod ke dalam
jadual dengan 1. Adakah jenis data AutoNumber yang disetkan untuk ID_Murid
menggunakan merupakan satu pilihan yang tepat? Berikan alasan kepada
borang jawapan anda.

goo.gl/YyJgNa 2. Jika AutoNumber tidak digunakan, apakah jenis data lain yang
sesuai? Jelaskan.

3. Jika anda menukarkan jenis data untuk ID_Murid dalam jadual
MARKAH, bagaimana dengan ID_Murid dalam jadual MURID?
Jelaskan.

4. Apakah cara lain untuk menghasilkan borang selain menggunakan
Form Wizard?

4.3

1. Lancarkan perisian aplikasi Microsoft Access.
2. Ikuti langkah-langkah dalam Rajah 4.27 untuk membina borang daripada dua jadual.
3. Kemudian, masukkan data ke dalam Borang yang dihasilkan.

148

Pangkalan Data dan SQL 4.1

4.5

Membina Borang Kaedah Pembentangan
1. Jadual berikut menunjukkan satu rekod pesakit. Hasil Sendiri

ID Pesakit : SA00174180 Kewarganegaraan : Malaysia

Nama Pesakit : Norain binti Ramli No. Fail : MR00158050

Jantina : Perempuan No. Wad :2

Tarikh Lahir : 02/07/1975 No. Katil : 14

Umur : 43 Penyakit : Darah Tinggi

Bangsa : Melayu Nama Doktor : Dr. Zainuddin bin Ismail

Alamat : No. 3, Jalan Payung,
47800 Petaling Jaya

2. Anda diminta membentuk kumpulan.
3. Berdasarkan maklumat dalam jadual di atas, anda diminta untuk mengenal

pasti dua entiti dan atribut-atribut yang sesuai. Hasil dapatan anda perlu
ditulis pada kertas.
4. Setelah masa yang diperuntukkan tamat, ahli-ahli dalam kumpulan perlu berkumpul
dan membentangkan hasil dapatan masing-masing.
5. Dalam kumpulan, semua murid diminta menunjukkan jawapan masing-masing.

4.4

Membina Pangkalan Data bagi Hasil Dapatan Dalam Aktiviti 4.5
1. Lancarkan perisian aplikasi Microsoft Access.
2. Ikuti langkah-langkah untuk membina pangkalan data yang telah anda pelajari

dalam subtopik 4.1.5 untuk membina pangkalan data bagi hasil dapatan anda dalam
Aktiviti 4.5.
3. Setelah berjaya membina pangkalan data, anda perlu menghasilkan borang dan
memasukkan data ke dalam jadual melalui borang yang dibina.
4. Anda boleh mengkaji semula Rajah 4.25, Rajah 4.27 dan Rajah 4.28 untuk mengetahui
langkah-langkah menghasilkan borang dan memasukkan data baharu ke dalam jadual
melalui borang.

149

Pembelajaran 4.1.7 Penggunaan Pernyataan-pernyataan
SQL
Murid boleh:
4.1.7 M enggunakan Perisian aplikasi Sistem Pengurusan Pangkalan Data (DBMS)
menggunakan arahan SQL untuk mencapai data dari rekod yang
arahan SQL yang disimpan dalam pangkalan. SQL mempunyai sintaks tertentu
melibatkan: yang mesti diikuti semasa digunakan. Sintaks merupakan set
(i) SELECT… peraturan yang menetapkan set perintah yang boleh digunakan
(ii) SELECT…WHERE dan cara-cara menulis perintah-perintah dalam bentuk ayat agar
(iii) SELECT…ORDER boleh difahami dan dilaksanakan oleh perisian aplikasi Sistem
Pengurusan Pangkalan Data (DBMS). Sintaks bagi SQL adalah
BY berasaskan sintaks dalam bahasa Inggeris.

Semua contoh pernyataan SELECT yang akan dibincangkan akan menggunakan entiti
MURID seperti Rajah 4.30.

MURID Nama_Murid Jantina Kaum Nama_Kelas Nama_Guru_Kelas
DAMIA ZAHRAA BINTI RAHIM PEREMPUAN MELAYU 3 ASERTIF FATIMAH BINTI SEMAN
ID_Murid DHIA ARISSA BINTI MALIK PEREMPUAN MELAYU 3 BIJAK ZAKIAH BINTI YUSOF
+ SM101 DENISH RAIMI BIN ZAINAL MELAYU 3 CEKAL MUSTAFA BIN ROSLAN
+ SM102 LELAKI 3 DINAMIK
+ SM103 TAN XUE LIEH LELAKI CINA 3 EFISIEN TEOH JEE YEE
+ SM104 KUMAR A/L RAMESH LELAKI INDIA 3 FIKIR RIMALA A/P SAMY
+ SM105 JESSICA HENG MUI MUI 3 GIGIH LIM CHOII PENG
+ SM106 PEREMPUAN CINA 3 EFISIEN CHANDRAN A/L SUMAN
+ SM107 KHAIR MUIZ BIN ABD RAHIM LELAKI MELAYU RIMALA A/P SAMY
+ SM108 DEVI A/P MUTHU
PEREMPUAN INDIA

Rajah 4.30  Entiti MURID

Jadual 4.6, 4.7 dan 4.8 menunjukkan keterangan dan contoh masing-masing untuk
pernyataan SELECT..., pernyataan SELECT...WHERE dan pernyataan SELECT...ORDER BY.

Jadual 4.6  Keterangan dan contoh untuk pernyataan SELECT

(i)  Pernyataan SELECT Contoh
Keterangan Sintaks Umum
SELECT atribut_1, atribut_2, atribut_3, atribut_N
Pernyataan SELECT FROM nama_jadual;
membenarkan anda untuk
memilih atribut-atribut yang
dikehendaki dari pangkalan data.

Pernyataan FROM membenarkan
anda memilih entiti bagi atribut-
atribut yang telah dipilih dalam
pernyataan SELECT. Pernyataan
FROM secara spesifik menyatakan
nama entiti yang digunakan untuk
capaian data.

150

Pangkalan Data dan SQL 4.1

Pernyataan SELECT…FROM Contoh 1
memulangkan nilai-nilai Pemilihan dua atribut sahaja daripada entiti MURID.
daripada atribut yang telah
dipilih berdasarkan entiti yang SELECT ID_Murid, Nama_Murid
telah ditetapkan. FROM MURID;

Output
Paparan output jelas menunjukkan bahawa hanya data
bagi dua atribut sahaja, iaitu ID_Murid dan Nama_
Murid telah dicapai daripada entiti MURID. Output
yang terhasil adalah seperti Rajah 4.31.

Pertanyaan 1 Nama_Murid
DAMIA ZAHRAA BINTI RAHIM
ID_Murid DHIA ARISSA BINTI MALIK
SM101 DENISH RAIMI BIN ZAINAL
SM102
SM103 TAN XUE LIEH
SM104 KUMAR A/L RAMESH
SM105 JESSICA HENG MUI MUI
SM106
SM107 KHAIR MUIZ BIN ABD RAHIM
SM108 DEVI A/P MUTHU

Rajah 4.31  Output Pertanyaan 1

Pernyataan SELECT * FROM Contoh 2
pula akan mencapai data bagi Pemilihan semua atribut daripada entiti MURID.
semua atribut yang terdapat
dalam entiti yang telah SELECT *
ditetapkan. FROM MURID;

Output
Paparan output jelas menunjukkan bahawa data bagi
semua atribut, iaitu ID_Murid, Nama_Murid, Jantina,
Kaum, Nama_Kelas dan Nama_Guru_Kelas telah
dicapai daripada entiti MURID. Output yang terhasil
adalah seperti Rajah 4.32.

Baris akhir sintaks Pertanyaan 2 Nama_Murid Jantina Kaum Nama_Kelas Nama_Guru_Kelas
SQL tidak perlu DAMIA ZAHRAA BINTI RAHIM PEREMPUAN MELAYU 3 ASERTIF FATIMAH BINTI SEMAN
berakhir dengan simbol ID_Murid DHIA ARISSA BINTI MALIK PEREMPUAN MELAYU 3 BIJAK ZAKIAH BINTI YUSOF
semicolon (;) tetapi SM101 DENISH RAIMI BIN ZAINAL LELAKI MELAYU 3 CEKAL MUSTAFA BIN ROSLAN
ianya merupakan SM102 LELAKI CINA 3 DINAMIK TEOH JEE YEE
praktis yang baik dalam SM103 TAN XUE LIEH LELAKI INDIA 3 EFISIEN RIMALA A/P SAMY
pengaturcaraan. SM104 KUMAR A/L RAMESH 3 FIKIR LIM CHOII PENG
SM105 JESSICA HENG MUI MUI PEREMPUAN CINA 3 GIGIH CHANDRAN A/L SUMAN
SM106 LELAKI MELAYU 3 EFISIEN RIMALA A/P SAMY
SM107 KHAIR MUIZ BIN ABD RAHIM
SM108 DEVI A/P MUTHU PEREMPUAN INDIA

Rajah 4.32  Output Pertanyaan 2

151

Jadual 4.7  Keterangan dan contoh untuk pernyataan SELECT...WHERE

(ii)  Pernyataan SELECT…WHERE

Keterangan Contoh

Pernyataan SELECT… Sintaks Umum
WHERE hampir serupa SELECT atribut_1, atribut_2,…atribut_N
dengan pernyataan SELECT… FROM nama_jadual
FROM. Perbezaan utama WHERE kriteria;
ialah pernyataan SELECT…
WHERE mencapai data-data Contoh
yang tertentu yang memenuhi Pemilihan atribut yang memenuhi sesuatu kriteria.
sesuatu kriteria sahaja. Oleh
itu, data yang dicapai lebih Katakan anda ingin memilih beberapa atribut yang
khusus. memenuhi kriteria Jantina = “PEREMPUAN” daripada
entiti MURID. Maka anda perlu menulis sintaks
seperti berikut:

SELECT Nama_Murid, Jantina, Kaum
FROM MURID
WHERE Jantina = “PEREMPUAN”;

Kriteria yang telah ditetapkan ditulis dalam klausa
WHERE, iaitu Jantina = “PEREMPUAN”. Oleh itu,
carian bagi atribut Nama_Murid, Jantina dan Kaum
adalah berdasarkan kriteria PEREMPUAN.

Penulisan kriteria perlu Output
mempunyai simbol Paparan output jelas menunjukkan bahawa data bagi
pembuka dan penutup atribut-atribut seperti Nama_Murid, Jantina dan Kaum
kata (“”). Jika anda adalah berdasarkan kriteria PEREMPUAN telah dicapai
tidak berbuat demikian, daripada entiti MURID. Output yang terhasil seperti
maka akan berlaku ralat Rajah 4.33.
sintaks.
Pertanyaan 3 Jantina Kaum
PEREMPUAN MELAYU
Nama_Murid
DAMIA ZAHRAA BINTI RAHIM PEREMPUAN MELAYU
DHIA ARISSA BINTI MALIK PEREMPUAN CINA
JESSICA HENG MUI MUI PEREMPUAN INDIA
DEVI A/P MUTHU

Rajah 4.33  Output Pertanyaan 3

152

Pangkalan Data dan SQL 4.1

Jadual 4.8  Keterangan dan contoh untuk pernyataan SELECT…ORDER BY

(iii)  Pernyataan SELECT…ORDER BY

Keterangan Contoh

Pernyataan SELECT… Sintaks Umum
ORDER BY membolehkan SELECT atribut_1, atribut_2,…atribut_N
anda mengisih data yang FROM nama_jadual
dicapai mengikut susunan WHERE kriteria
menaik (ASC) atau susunan ORDER BY atribut_1 ASC/DESC;
menurun (DESC) berdasarkan Contoh 1
satu atau lebih daripada satu Penggunaan ASC untuk mengisih secara menaik.
medan isihan.

Sekiranya ASC ditaip, SELECT Nama_Murid, Jantina, Kaum
rekod-rekod yang dicapai FROM MURID
akan diisih secara menaik WHERE Jantina = “PEREMPUAN”
mengikut susunan abjad A-Z ORDER BY Nama_Murid ASC;
berdasarkan medan Output
isihan. Paparan output jelas menunjukkan bahawa data bagi
Jika DESC ditaip, maka atribut Nama_Murid telah diisih secara menaik.
rekod-rekod akan diisih
mengikut susunan abjad Z-A Pertanyaan 4 Jantina Kaum
berdasarkan medan isihan. PEREMPUAN
Nama_Murid MELAYU
DAMIA ZAHRAA BINTI RAHIM PEREMPUAN
DEVI A/P MUTHU PEREMPUAN INDIA
DHIA ARISSA BINTI MALIK PEREMPUAN MELAYU
JESSICA HENG MUI MUI CINA

Rajah 4.34  Output Pertanyaan 4

Contoh 2
Penggunaan DESC untuk mengisih secara menurun.

SELECT Nama_Murid, Jantina, Kaum
FROM MURID
WHERE Jantina = “PEREMPUAN”
ORDER BY Nama_Murid DESC;
Output
Paparan output jelas menunjukkan bahawa data bagi
atribut Nama_Murid telah diisih secara menurun.

Pertanyaan 5 Jantina Kaum
PEREMPUAN CINA
Nama_Murid
JESSICA HENG MUI MUI PEREMPUAN MELAYU
DHIA ARISSA BINTI MALIK PEREMPUAN INDIA
DEVI A/P MUTHU PEREMPUAN MELAYU
DAMIA ZAHRAA BINTI RAHIM

Rajah 4.35  Output Pertanyaan 5

153

†† Langkah-langkah menghasilkan pertanyaan (query) dengan menggunakan SQL

Pertanyaan (query) bermaksud pertanyaan kepada pangkalan data hubungan dalam bahasa
query untuk mencapai data dan maklumat yang disimpan dalamnya. Pernyataan SQL yang
telah anda pelajari ialah pertanyaan (query).

Capaian data dan maklumat daripada pangkalan data yang dibina dengan perisian
aplikasi Microsoft Access dapat dilakukan dengan menggunakan arahan SQL. Pertanyaan
(query) dapat dihasilkan dengan menggunakan pernyataan-pernyataan SQL yang telah
anda pelajari. Rajah 4.36 menunjukkan langkah-langkah menghasilkan pertanyaan (query)
dengan menggunakan arahan SQL.

Langkah 1 Klik Create di bar Menu, Langkah 2 Pilih entiti MURID dan klik Add.
kemudian klik Query Design.

1. Klik Create.
2.  Klik Query
Design.

1.  Pilih jadual
MURID.

2. Klik Add.

Langkah 3 Jadual MURID telah ditambah. Langkah 4 Klik View dan pilih SQL View.

Jadual murid yang Klik View dan
ditambahkan. pilih SQL View.

154

Langkah 5 Taip SELECT * FROM MURID Pangkalan Data dan SQL 4.1
dalam Query1. Kemudian klik
Run. Langkah 6 Data yang dicapai akan terpapar
dalam Query1. Halakan kursor
2. Klik Run. tetikus pada perkataan Query1
dan klik kanan, kemudian klik Save.
Halakan kursor tetikus pada
perkataan Query1 dan klik
kanan, kemudian klik Save.

1. Taip pernyataan SQL ini.
Langkah 7 Tetingkap Save As terpapar.Tukarkan nama Query1 kepada PERTANYAAN 1 dan klik OK.

Taipkan PERTANYAAN 1
dan klik OK.
Langkah 8 Paparan berikut menunjukkan query SELECT * yang telah disimpan dan paparan data yang dicapai.
Capaian data bagi query
PERTANYAAN 1.

Query yang disimpan.
Rajah 4.36  Langkah-langkah menghasilkan pertanyaan (query) dengan menggunakan SQL

Anda digalakkan memasukkan nama yang bersesuaian dengan kehendak pertanyaan (query)
yang dibina.

155

4.6

Pertanyaan(Query) Menggunakan Arahan SQL Kaedah
Gallery Walk

Andaikan anda seorang pembangun sistem pangkalan data. Anda telah ditugaskan untuk
membangunkan Sistem Maklumat Kokurikulum. Sebagai pembangun sistem maklumat
ini, anda telah berjaya menghasilkan entiti MURID dan entiti GURU PENASIHAT.

MURID GURU_PENASIHAT

ID_Murid Nama_Murid Nama_Kelas ID_Guru ID_Murid Nama_Guru Persatuan Unit_Beruniform Sukan
+ M001 SOFIA BINTI JAMAL 3 JATI BOLA JARING
+ M002 ANAS BIN SUFIAN 3 JATI GP01 M001 AZLINA BINTI AZMI BAHASA MELAYU KADET POLIS BOLA KERANJANG
+ M003 GP02 M002 BOLA KERANJANG
+ M004 WONG MUI LING 3 MERBAU GP03 M003 ARSHAD BIN YUSOFF BAHASA MELAYU KADET POLIS BADMINTON
+ M005 3 MERBAU GP04 M004 BADMINTON
ANANTH A/L SAVOO 3 CENGAL GP05 M005 TANG SIANG HENG MATEMATIK KADET POLIS
MELISSA YAP LI LING
ANGELINA KHOO XING XUE MATEMATIK PANDU PUTERI

THULASI A/P MARIAPPAN SAINS PANDU PUTERI

Lakukan aktiviti dan jawab soalan-soalan berikut berdasarkan jadual-jadual bagi entiti
MURID dan entiti GURU_PENASIHAT.
1. Anda diminta membentuk kumpulan.
2. Setiap murid diminta menulis pertanyaan SQL yang sesuai untuk mendapatkan paparan

PERTANYAAN 1, PERTANYAAN 2, PERTANYAAN 3 DAN PERTANYAAN 4.

PERTANYAAN 1

ID_Guru ID_Murid Nama_Guru Persatuan Unit_Beruniform Sukan
KADET POLIS BOLA JARING
GP01 M001 AZLINA BINTI AZMI BAHASA MELAYU KADET POLIS BOLA KERANJANG
GP02 M002 ARSHAD BIN YUSOFF BAHASA MELAYU KADET POLIS BOLA KERANJANG
GP03 M003 TANG SIANG HENG MATEMATIK PANDU PUTERI BADMINTON
GP04 M004 MATEMATIK PANDU PUTERI BADMINTON
GP05 M005 ANGELINA KHOO XING XUE SAINS
THULASI A/P MARIAPPAN

PERTANYAAN 2

ID_Guru ID_Murid Nama_Guru Unit_Beruniform PERTANYAAN 3
KADET POLIS
GP01 M001 AZLINA BINTI AZMI KADET POLIS ID_Guru Nama_Guru Persatuan Sukan
GP02 M002 ARSHAD BIN YUSOFF KADET POLIS
GP03 M003 TANG SIANG HENG GP02 ARSHAD BIN YUSOFF BAHASA MELAYU BOLA KERANJANG
GP01 AZLINA BINTI AZMI
BAHASA MELAYU BOLA JARING

PERTANYAAN 4

ID_Guru ID_Murid Nama_Guru

GP05 M005 THULASI A/P MARIAPPAN
GP04 M004 ANGELINA KHOO XING XUE
GP03 M003 TANG SIANG HENG
GP02 M002
GP01 M001 ARSHAD BIN YUSOFF
AZLINA BINTI AZMI

3. Anda perlu berbincang dalam kumpulan dan jawapan terakhir perlu ditulis pada kertas.
4. Setelah masa perbincangan tamat, setiap kumpulan diminta untuk menampalkan

jawapan masing-masing pada dinding yang berdekatan dengan tempat mereka berada.
5. Setiap kumpulan akan bergerak dari satu kumpulan ke kumpulan yang lain sehingga

semua kumpulan telah habis dilawati bagi tujuan membuat penilaian terhadap hasil
kerja kumpulan yang lain.
6. Setiap ahli kumpulan perlu menulis komen terhadap hasil kerja kumpulan yang lain
dengan menggunakan pen yang berlainan warna.

156

Pangkalan Data dan SQL 4.1

4.5

Menghasilkan Pangkalan Data dan Pertanyaan (Query)
1. Lancarkan perisian aplikasi Microsoft Access.
2. Hasilkan entiti MURID dan entiti GURU_PENASIHAT yang ditunjukkan dalam

Aktiviti 4.6.
3. Berdasarkan pertanyaan-pertanyaan SQL yang anda peroleh daripada Aktiviti 4.6,

hasilkan PERTANYAAN 1, PERTANYAAN 2, PERTANYAAN 3 dan PERTANYAAN 4.
4. Rujuk semula Rajah 4.36 untuk langkah-langkah menghasilkan pertanyaan (query).
5. Setelah berjaya, tunjukkan kepada guru anda untuk disemak.

4.1.8 Penggunaan Pernyataan-pernyataan Pembelajaran
SQL yang Melibatkan Ungkapan
Boolean Murid boleh:
4.1.8  Menggunakan
Semasa membuat pertanyaan (query), anda mungkin pernah
berada dalam situasi yang memerlukan anda menggunakan arahan SQL
operator logik. Operator logik juga dikenali sebagai operator melibatkan
boolean. Operator logik yang digunakan dalam arahan SQL ungkapan Boolean:
ialah OR, AND, EQV, NOT dan XOR. Akan tetapi, operator (i) Operator OR
OR dan operator AND ialah dua operator logik yang paling (ii) Operator AND
kerap digunakan.
Video tentang
Operator logik digunakan untuk menggabungkan dua atau operator OR dan
lebih kriteria bagi menghasilkan satu ungkapan boolean. Ungkapan operator AND
boolean akan memberi nilai BENAR atau PALSU. Penggunaan dalam SQL
operator logik dalam arahan SQL membenarkan pelbagai kriteria
atau syarat digabungkan untuk menghasilkan pertanyaan yang goo.gl/5fLhrc
lebih kompleks untuk mencapai data yang dikehendaki.
157
(i) Operator OR

Apabila operator OR digunakan untuk menggabungkan dua
kriteria P dan Q, ungkapan P OR Q akan dihasilkan. Nilai boolean
BENAR akan dipulangkan jika salah satu kriteria P atau Q adalah
benar. Jadual 4.9 menunjukkan jadual kebenaran OR.

Jadual 4.9  Jadual kebenaran OR

P Q P OR Q
BENAR BENAR BENAR
BENAR PALSU BENAR
PALSU BENAR BENAR
PALSU PALSU PALSU

Nilai boolean BENAR Operator OR digunakan untuk menggabungkan pelbagai
dan PALSU juga kriteria atau syarat yang ditetapkan dalam klausa WHERE.
kadangkala diwakili Pernyataan SQL yang berikut menunjukkan sintaks umum
oleh nombor 1 dan 0, penggunaan operator OR dalam klausa WHERE.
di mana 1 mewakili
BENAR dan 0 mewakili SELECT atribut_1, atribut_2, …, atribut_N
PALSU. Operator OR FROM nama_jadual
boleh diwakili dengan WHERE kriteria_1 OR kriteria_2, … OR kriteria_N;
simbol (v). Jadual
kebenaran OR berikut Rajah 4.37 menunjukkan jadual bernama MURID.
berdasarkan nombor 0, Pernyataan SQL dalam Contoh 4.10 dan Contoh 4.11 adalah
1 dan simbol v. berdasarkan jadual ini.

P Q PvQ MURID Nama_Murid Jantina Kaum Nama_Kelas Nama_Guru_Kelas
DAMIA ZAHRAA BINTI RAHIM PEREMPUAN MELAYU FATIMAH BINTI SEMAN
11 1 ID_Murid DHIA ARISSA BINTI MALIK PEREMPUAN MELAYU 3 ASERTIF ZAKIAH BINTI YUSOF
+ SM101 DENISH RAIMI BIN ZAINAL MELAYU 3 BIJAK MUSTAFA BIN ROSLAN
10 1 + SM102 TAN XUE LIEH LELAKI 3 CEKAL
+ SM103 KUMAR A/L RAMESH LELAKI CINA 3 DINAMIK TEOH JEE YEE
01 1 + SM104 JESSICA HENG MUI MUI LELAKI INDIA 3 EFISIEN RIMALA A/P SAMY
+ SM105 KHAIR MUIZ BIN ABD RAHIM PEREMPUAN CINA 3 FIKIR LIM CHOII PENG
+ SM106 DEVI A/P MUTHU LELAKI MELAYU 3 GIGIH CHANDRAN A/L SUMAN
+ SM107 PEREMPUAN INDIA 3 EFISIEN RIMALA A/P SAMY
+ SM108

00 0 Rajah 4.37  Jadual bagi entiti MURID

4.6 Penggunaan operator OR dalam pernyataan
SQL.

4.14 Pernyataan SQL berikut menunjukkan penggunaan operator
OR dalam klausa WHERE untuk mendapatkan data yang
Apakah yang memenuhi salah satu daripada dua kriteria yang dinyatakan,
dimaksudkan dengan iaitu kriteria jantina ialah perempuan atau kriteria kaum ialah
kriteria_N? Melayu.

SELECT ID_Murid, Nama_Murid, Jantina, Kaum
FROM MURID
WHERE Jantina =“PEREMPUAN” OR Kaum =“MELAYU”;

Rajah 4.38 menunjukkan output yang terhasil daripada
pernyataan SQL di atas.

OPERATOR OR

ID_Murid Nama_Murid Jantina Kaum
PEREMPUAN MELAYU
SM101 DAMIA ZAHRAA BINTI RAHIM PEREMPUAN MELAYU
SM102 DHIA ARISSA BINTI MALIK LELAKI MELAYU
SM103 PEREMPUAN CINA
DENISH RAIMI BIN ZAINAL LELAKI MELAYU
PEREMPUAN
SM106 JESSICA HENG MUI MUI INDIA
SM107 KHAIR MUIZ BIN ABD RAHIM
SM108 DEVI A/P MUTHU

Rajah 4.38  Output pertanyaan OPERATOR OR

158

Pangkalan Data dan SQL 4.1

(ii) Operator AND Penerangan
Apabila operator AND digunakan untuk menggabung dua operator OR dan
kriteria P dengan Q, ungkapan P AND Q akan dihasilkan. Nilai operator AND
boolean BENAR akan dipulangkan hanya apabila kedua-dua dalam SQL
kriteria P dan Q adalah BENAR. Jadual 4.10 menunjukkan
jadual kebenaran AND. goo.gl/z4Ehc9

Jadual 4.10  Jadual kebenaran AND

P Q P AND Q

BENAR BENAR BENAR
BENAR PALSU PALSU
PALSU BENAR PALSU

PALSU PALSU PALSU Jadual kebenaran
ungkapan boolean yang
Pernyataan SQL yang berikut menunjukkan sintaks umum menggunakan operator
penggunaan operator AND dalam klausa WHERE. AND (^) adalah seperti
berikut:

P Q P^Q

SELECT atribut_1, atribut_2, …, atribut_N 11 1
FROM nama_jadual
WHERE kriteria_1 AND kriteria_2 AND …kriteria_N; 10 0

01 0

00 0

4.7 Penggunaan operator AND dalam pernyataan SQL.
Pernyataan SQL berikut menunjukkan penggunaan operator AND dalam klausa WHERE
untuk mendapatkan data yang memenuhi kedua-dua kriteria yang dinyatakan, iaitu kriteria
jantina ialah perempuan atau kriteria kaum ialah Melayu.

SELECT ID_Murid, Nama_Murid, Jantina, Kaum
FROM MURID
WHERE Jantina = “PEREMPUAN” AND Kaum = “MELAYU”;

Rajah 4.39 menunjukkan output yang terhasil daripada pernyataan SQL di atas.

OPERATOR AND

ID_Murid Nama_Murid Jantina Kaum
PEREMPUAN MELAYU
SM101 DAMIA ZAHRAA BINTI RAHIM PEREMPUAN MELAYU
SM102 DHIA ARISSA BINTI MALIK

Rajah 4.39  Output pertanyaan OPERATOR AND

159

4.7

Arahan SQL yang Melibatkan Ungkapan Boolean Kaedah
Bus Stop

Rajah-rajah di bawah menunjukkan jadual entiti MURID dan entiti GURU_PENASIHAT.

MURID Nama_Murid Nama_Kelas
SOFIA BINTI JAMAL 3 JATI
ID_Murid ANAS BIN SUFIAN 3 JATI
+ M001
+ M002 WONG MUI LING 3 MERBAU
+ M003 3 MERBAU
+ M004 ANANTH A/L SAVOO 3 CENGAL
+ M005 MELISSA YAP LI LING

GURU_PENASIHAT

ID_Guru ID_Murid Nama_Guru Persatuan Unit_Beruniform Sukan
KADET POLIS
GP01 M001 AZLINA BINTI AZMI BAHASA MELAYU KADET POLIS BOLA JARING
GP02 M002 ARSHAD BIN YUSOFF BAHASA MELAYU KADET POLIS BOLA KERANJANG
GP03 M003 TANG SIANG HENG PANDU PUTERI BOLA KERANJANG
GP04 M004 MATEMATIK PANDU PUTERI
GP05 M005 ANGELINA KHOO XING XUE MATEMATIK BADMINTON
THULASI A/P MARIAPPAN BADMINTON
SAINS

Berdasarkan kedua-dua jadual ini, lakukan aktiviti dan jawab soalan-soalan berikut:
1. Anda diminta membentuk kumpulan.
2. Anda diminta menulis dua pernyataan SQL yang menggunakan operator OR dan

operator AND.
3. Setelah masa yang diberi untuk menulis pernyataan SQL tamat, guru memberikan

isyarat pertama supaya anda mula bergerak secara individu untuk melihat hasil
perbincangan rakan-rakan.
4. Apabila isyarat kedua dibunyikan, anda perlu kembali ke tempat asal dan berkongsi
maklumat yang diperoleh daripada kumpulan lain.
5. Anda diminta memaparkan output daripada pertanyaan dengan menggunakan
perisian aplikasi persembahan yang sesuai sebagai hasil perbincangan.

160

Pangkalan Data dan SQL 4.1

4.1.9 Menjana Laporan Berdasarkan Hasil Pembelajaran
Pertanyaan (Query)
Murid boleh:
Penggunaan laporan untuk mengurus dan mempersembahkan 4.1.9 M enjana laporan
data daripada pangkalan data merupakan satu cara yang
sistematik dan terbaik. Laporan membolehkan anda menetapkan berdasarkan hasil
format data dalam bentuk yang menarik dan bermaklumat bagi pertanyaan (query)
tujuan cetakan dan paparan pada skrin.
Video tentang
Laporan boleh dihasilkan berdasarkan maklumat daripada Report Wizard
satu jadual atau daripada beberapa jadual. Sekiranya maklumat
tersebut adalah daripada beberapa jadual, anda perlu goo.gl/PMCaVG
menghasilkan pertanyaan (query) untuk mencapai maklumat
yang dikehendaki terlebih dahulu. Laporan boleh dijana
berdasarkan pertanyaan yang dilakukan.

Dalam perisian aplikasi Microsoft Access, cara yang paling
mudah untuk menghasilkan laporan adalah dengan menggunakan
Report Wizard. Rajah 4.40 menunjukkan langkah-langkah
menjana laporan dengan menggunakan Report Wizard.
Langkah 1  Pada menu bar, klik Create. Kemudian, klik Report Wizard.

1. Klik Create. 2.  Klik Report
Wizard.

Langkah 2 P aparan tetingkap Report Wizard akan muncul. Pilih jadual Selain menggunakan
atau query yang anda ingin gunakan untuk menghasilkan Report Wizard, laporan
laporan. juga boleh dijana
menggunakan Report
dengan hanya satu klik.
Anda boleh mencubanya
nanti!

Klik untuk pilih
jadual atau query.

4.15

Apakah objek-objek
pangkalan data yang
boleh digunakan untuk
menghasilkan laporan?

161

Langkah 3  Setelah jadual atau pertanyaan dipilih, tetingkap Available Fields menunjukkan semua
medan yang ada di dalam jadual. Klik ikon >> untuk memilih semua medan.
Klik butang >>
untuk memilih
semua medan.

Langkah 4 M edan yang dipilih akan muncul dalam tetingkap Selected Fields. Klik Next.

Klik Next.
Langkah 5  Anda boleh klik ikon > atau < untuk menentukan susunan medan yang dipaparkan

dalam laporan. Klik Next.

162

Pangkalan Data dan SQL 4.1

Langkah 6  Anda boleh memilih medan untuk tujuan isihan dan klik Ascending atau Descending
untuk menentukan isihan secara menaik atau menurun. Klik Next.

Langkah 7 S eterusnya, pilih cara susun atur (Layout) dan orientasi (Orientation) untuk menetapkan
format laporan anda. Klik Next.

Langkah 8 M asukkan nama laporan anda. Klik Finish.

1.  Masukkan
nama laporan.

2. Klik Finish.

Rajah 4.40  Langkah-langkah menjana laporan dengan menggunakan Report Wizard

163

Langkah-langkah Rajah 4.41 menunjukkan contoh laporan yang dipaparkan
menghasilkan dalam susun atur (layout) yang berbeza, iaitu Stepped Layout,
laporan Block Layout dan Outline Layout.

goo.gl/AuqRNx

(a)  Stepped Layout

Bilangan maksimum (b)  Block Layout
atribut yang boleh
dimasukkan dalam
laporan adalah sebanyak
255.

4.16 (c)  Outline Layout
Rajah 4.41  Paparan laporan dalam susun atur (layout) yang berbeza
Bagaimanakah cara
untuk menamakan
semula laporan yang
telah disimpan?

4.6

Penjanaan Laporan Berdasarkan Hasil Pertanyaan (Query)
1. Rujuk kepada Contoh 4.6 dan 4.7, hasilkan pertanyaan bagi OPERATOR AND dan

OPERATOR OR.
2. Janakan laporan-laporan berdasarkan pertanyaan-pertanyaan yang telah dibuat.
3. Setelah berjaya, tunjukkan kepada guru anda untuk disemak.
4. Cetak satu set laporan yang telah dijana dan tampal di dalam kelas.

164

Pangkalan Data dan SQL 4.1

4.1

1. merupakan fakta yang belum diproses.

2. Pangkalan data ialah tempat pengumpulan dan penyimpanan data secara
bagi sistem maklumat yang berasaskan komputer.

3. Entiti merujuk kepada suatu objek yang dan boleh dikenal pasti
dalam persekitaran tertentu.

4. Atribut merupakan ciri-ciri yang menerangkan sesuatu .

5. Nyatakan dua kepentingan kekunci primer.

6. (a) Nyatakan maksud kekardinalan dalam pangkalan data.
(b) Berdasarkan situasi-situasi berikut, lakarkan jenis kekardinalan dalam lukisan

gambar rajah perhubungan entiti.
(i) Seorang murid meminjam buku dari perpustakaan sekolah.
(ii) Seorang warganegara Malaysia boleh memiliki satu Pasport Malaysia

Antarabangsa.

7. Nyatakan objek-objek pangkalan data yang terdapat dalam perisian aplikasi
Microsoft Access.

8. Nyatakan dua kegunaan utama borang (form) dalam pangkalan data.

9. (a) Apakah bahasa pertanyaan (query) yang digunakan untuk memanipulasi data-data
dalam pangkalan data?

(b) Nyatakan pernyataan-pernyataan yang telah anda pelajari.

10. Berdasarkan pertanyaan (query) di bawah, nyatakan semua jadual (table) dan atribut
(fields) yang terlibat.

SELECT ID_Murid, Nama_Murid
FROM MURID;


11. Lengkapkan jadual kebenaran bagi ungkapan Boolean yang menggunakan operator OR
dan operator AND.

Operator OR Operator AND

P Q P∨Q P Q P∧Q
11 11
10 10
01 01
00 00

165

12. Nyatakan cara untuk menghasilkan laporan dengan mudah yang telah anda pelajari.
13. Berikut menunjukkan dua jadual bagi entiti BUTIR_MURID dan entiti BUTIR_PENJAGA.

BUTIR_MURID

ID_Murid Nama Jantina Kaum Agama

+ T17-124 DENISH RAIMI BIN MALIK LELAKI MELAYU ISLAM
TAN CHEN HONG LELAKI CINA BUDDHA
+ T17-125 PEREMPUAN
+ T17-182 NURUL AIN BINTI AHMAD MELAYU ISLAM

+ T17-201 PRIYA DAVID PEREMPUAN INDIA KRISTIAN
+ T17-202 ARUL A/L PARAM LELAKI INDIA HINDU

+ T 1 7-2 2 5 RACHEL LIM YEE LING PEREMPUAN CINA KRISTIAN

BUTIR_PENJAGA ID_Murid Nama_Ibu Nama_Bapa No_Telefon
YEOH MIN LI TAN TZE SOOK 009-1234567
No_Daftar T17-125 DIYVA A/P SAMY DAVID THOMAS 009-7654321
1111 GAN PUI MUI RICHARD LIM KAH PEW 009-1122334
1112 T17-201 MALIK BIN RASHID 009-2211334
1113 SITI NOOR BINTI ALI AHMAD BIN RAHMAN 009-3322115
1114 T17-225 SARAH BINTI HASSAN 009-4433115
1115 T17-124 PARAM A/L GOPAL
1116 T17-182 KARISHMA A/P SIVA
T17-202

Tuliskan pertanyaan-pertanyaan (queries) yang sesuai untuk memperoleh paparan
yang berikut.
(a) (c)

PERTANYAAN A PERTANYAAN C

Nama_Ibu Nama_Bapa ID_Murid Nama Kaum
YEOH MIN LI TAN TZE SOOK CINA
DIYVA A/P SAMY DAVID THOMAS T17-125 TAN CHEN HONG CINA

T17-225 RACHEL LIM YEE LING

GAN PUI MUI RICHARD LIM KAH PEW

SITI NOOR BINTI ALI MALIK BIN RASHID

SARAH BINTI HASSAN AHMAD BIN RAHMAN

KARISHMA A/P SIVA PARAM A/L GOPAL

(b) (d)

PERTANYAAN B PERTANYAAN D

ID_Murid Nama Kaum Nama Jantina Kaum

T17-202 ARUL A/L PARAM INDIA ARUL A/L PARAM LELAKI INDIA
T17-124 MELAYU
DENISH RAIMI BIN MALIK MELAYU DENISH RAIMI BIN MALIK LELAKI
T17-182 CINA
T17-201 NURUL AIN BINTI AHMAD MELAYU TAN CHEN HONG LELAKI

PRIYA DAVID INDIA

T 1 7-2 2 5 RACHEL LIM YEE LING CINA

T17-125 TAN CHEN HONG
CINA

166

Struktur Kod Arahan 4.2

4.2 STRUKTUR KOD ARAHAN

Dalam kehidupan seharian, suatu masalah harus dianalisis, Python ialah bahasa
dikenal pasti dan dibahagikan kepada beberapa submasalah pengaturcaraan sumber
melalui proses leraian supaya masalah tersebut bukan sahaja terbuka. Python telah
kelihatan kurang rumit tetapi lebih mudah untuk diselesaikan. mengalami banyak
Bagi setiap submasalah, suatu algoritma khusus boleh dihasilkan. penambahbaikan
Gabungan kesemua algoritma yang dihasilkan akan mampu dengan keluaran
menyelesaikan masalah asal tersebut. versi-versi baharu sejak
mula digunakan pada
Pembangunan atur cara juga dilakukan dengan cara yang tahun 1991.
sama. Masalah pengaturcaraan dibahagikan kepada tugas utama
dan beberapa tugas kecil (subtugas). Bagi setiap tugas kecil, satu
algoritma dapat dibina.

Semasa fasa pengekodan, algoritma bagi tugas utama
diterjemahkan kepada atur cara utama dan algoritma setiap tugas
kecil diterjemahkan kepada subatur cara yang dipanggil function
atau procedure. Function dan procedure akan diguna pakai dalam
atur cara utama bagi menyelesaikan masalah tersebut.

4.2.1 Fungsi Function dan Procedure dalam Pembelajaran
Atur Cara
Murid boleh:
(i) Function 4.2.1  Menerangkan fungsi
Function sesuai digunakan bagi subtugas yang perlu memulangkan
satu nilai selepas tugas itu diselesaikan. Sebagai contoh, dalam struktur berikut
permainan yang melibatkan pembelian, situasi pengiraan dana dalam atur cara:
yang sedia ada dan baki dana selepas pembelian diperlukan. (i) Function
Function sesuai digunakan bagi proses pengiraan kerana kod (ii) Procedure
yang sama tidak perlu ditulis semula setiap kali pemain ingin
melakukan pembelian. Rajah 4.42 dan Rajah 4.43 menunjukkan Function dan
paparan simulasi aplikasi android MyStemVille bagi peringkat procedure
pembelian.
goo.gl/LGsjnK
Apabila pemilihan dibuat dan pembelian disahkan, function
yang berada di belakang item-item yang dipilih itu akan terlaksana.
Pengiraaan berlaku dan baki terakhir dikemaskinikan di ruang
penjuru sebelah kiri. Perhatikan bahawa sebelum pembelian,
baki sedia ada ialah 220 dan selepas pembelian disahkan, baki
terbaharu ialah 20 iaitu proses pengiraan dilakukan oleh function
dan nilai baki terakhir dipulangkan untuk dipaparkan.

167

Baki sedia ada Pemain pilih untuk Baki selepas pembelian Item baharu berada
ialah 220. membeli item ini. ialah 20. dalam taman pemain.

Rajah 4.42  Paparan simulasi permainan MyStemVille

(ii) Procedure

Permainan android Procedure sesuai digunakan dalam situasi di mana satu tugas perlu
ini boleh dimuat dilaksanakan berulang kali apabila ia diperlukan tanpa pemulangan
turun dari Google nilai. Perhatikan bahawa procedure yang disimpan dalam butang
Play Store atau scan profil akan terlaksana setiap kali butang ini diklik. Procedure
QR code ini. ini akan memaparkan tetingkap yang mengandungi profil pemain
seperti yang ditunjukkan dalam Rajah 4.43.

goo.gl/82yD3g Rajah 4.43  Paparan profil pemain
Penggunaan subatur cara seperti function dan procedure
sesuai untuk pelaksanaan tugas yang khusus atau berulang
kali dalam satu atur cara yang sama atau dalam atur cara yang
berlainan. Ini menjadikan kod arahan seluruh atur cara menjadi
lebih kemas, teratur, sistematik, bersifat modular dan lebih
mudah dinyahpepijat serta diselenggara.

Penggunaan function dan procedure dalam menghasilkan suatu atur cara merupakan satu
pendekatan yang harus dikuasai oleh setiap murid. Kemahiran ini akan membolehkan murid
memainkan peranannya sebagai team player dalam menghasilkan atur cara yang bertaraf
komersial.

Dalam kebanyakan bahasa pengaturcaraan, function dan procedure mempunyai
persamaan dan perbezaan yang jelas dari segi takrifan dan kegunaan. Dalam bahasa
pengaturcaraan Python, procedure tidak wujud kerana procedure dianggap sebagai implicit
function. Procedure Python tetap memulangkan nilai None walaupun memainkan peranan

168

yang sama seperti procedure dalam bahasa pengaturcaraan Struktur Kod Arahan 4.2
yang lain, iaitu tidak melakukan sebarang pengiraan dan hanya
memaparkan maklumat. None ialah nilai lalai dalam Python. Perbezaan antara
Takrifan dan kegunaan function serta procedure dalam buku ini function dan
akan dibuat berdasarkan bahasa pengaturcaraan Python. Rajah procedure dalam
4.44 menunjukkan persamaan dan perbezaan antara function Python.
dan procedure Python.
goo.gl/5jxz9z
Parameter ialah pemboleh ubah yang digunakan oleh sesuatu (Dipetik dari: http://
function atau procedure. index-of.es/Python/
Argumen ialah data atau nilai sebenar dalam pemboleh ubah Core.Python.
tersebut. Programming.2nd.
Edition.Wesley.
Chun.2006.pdf,
muka surat 448)

Ada dua jenis, Mempunyai nama Ditulis
(a)  yang sedia ada khusus yang oleh
eksplisit pengguna
(built-in function).
(b)  yang ditulis oleh Berparameter
ataupun tidak
pengguna berparameter
(user-defined) Melaksanakan
satu urutan arahan
Perlu Function bagi menyelesaikan Procedure Tidak
menerima semestinya
nilai input satu tugas menerima input
(argumen) khusus (argumen)

Memulangkan satu Boleh digunakan Tidak memulangkan
atau beberapa nilai. berulang kali dalam sebarang nilai
(nombor, aksara atau
atur cara yang kecuali nilai secara
jenis data lain) sama atau berbeza lalai: None.

sekiranya perlu

Rajah 4.44  Persamaan dan perbezaan antara function dan procedure Python

169

Pembelajaran 4.2.2 Penggunaan Pernyataan Function

Murid boleh: Function boleh dibahagikan kepada built-in function (fungsi
4.2.2 M emberi contoh dalaman) dan user-defined function (fungsi dihasilkan sendiri).
Kedua-duanya mempunyai fungsi yang sama, iaitu melakukan
penggunaan suatu tugas yang khusus.
penyataan function:
(i) dalaman (i) Function dalaman (built-in)
Built-in function ialah fungsi yang sedia ada dan disimpan dalam
(built-in) library bahasa pengaturcaraan. Kod sumber untuk setiap built-in
(ii) dihasilkan function tidak boleh dilihat oleh pengatur cara. Setiap built-in
function mempunyai nama yang deskriptif, iaitu nama yang dapat
sendiri mencerminkan tugas built-in function berkenaan. Nama built-in
(user-defined) function tidak boleh ditukar. Dalam pengaturcaraan Python,
fungsi input dan fungsi output ialah built-in function yang sering
Function digunakan. Tugas yang dilakukan oleh built-in function yang
dalaman bahasa dibekalkan adalah terhad dan ringkas sahaja.
pengaturcaraan
Python Bagi kebanyakan bahasa pengaturcaraan, sebelum sesuatu
built-in function boleh digunakan, nama fail library di mana
goo.gl/DWBx41 built-in function berkenaan disimpan hendaklah dinyatakan
terlebih dahulu di bahagian atas atur cara. Dalam pengaturcaraan
Python, terdapat sekumpulan built-in function yang boleh
digunakan secara terus tanpa menyatakan terlebih dahulu nama
fail library di mana fungsi berkenaan disimpan.

4.8 Penggunaan built-in function dalam bahasa pengaturcaraan Python.

Contoh ini menunjukkan penggunaan built-in function sum( ), max( ), min( ) dan index( )
bagi mendapatkan nama murid yang memperoleh jumlah markah tertinggi dan terendah.
Jadual 4.11 menunjukkan markah yang diperoleh lima murid bagi empat mata pelajaran.

Jadual 4.11

ID murid Nama murid BM BI Mate Sains
0001 Ali bin Azmi 87 70 80 78
0002 Aminah binti Yusof 95 80 65 75
0003 Chong Yee Ling 74 85 90 85
0004 Dayang Minsu 55 85 71 68
0005 Denish A/L Kathigasu 65 78 68 65

170

Struktur Kod Arahan 4.2

Markah Min dan Mak.py - C:\Documents\Tutorial Python\Markah Min dan Mak.py (3.6.5)

File Edit Format Run Options Window Help

#Menyimpan markah setiap murid dalam senarai

murid_1 = [87, 70, 80, 78] Semua markah bagi setiap murid mesti disimpan dalam
murid_2 = [95, 80, 65, 75]
senarai masing-masing.
murid_3 = [74, 85, 90, 85]

murid_4 = [55, 85, 71, 68]

murid_5 = [65, 78, 68, 65]

#Menyimpan nama setiap murid dalam urutan senarai nama

nama = ["Ali bin Azmi", "Aminah binti Yusof", "Chong Yee Ling", "Dayang Minsu",

"Denish A/L Kathigasu"] Nama semua murid harus disimpan dalam satu senarai

mengikut tertib senarai markah.

#Menjumlahkan markah setiap murid

jumlah_1 = sum(murid_1) Senarai markah setiap murid dihantar ke built-in function sum( ) dan
jumlah_2 = sum(murid_2) nilai yang dipulangkan, iaitu jumlah markah disimpan dalam pemboleh
jumlah_3 = sum(murid_3)
ubah yang sepadan.
jumlah_4 = sum(murid_4)

jumlah_5 = sum(murid_5)

#Menyimpan jumlah markah setiap murid dalam senarai jumlah
jumlah = [jumlah_1, jumlah_2, jumlah_3, jumlah_4, jumlah_5]

Jumlah markah setiap murid disimpan dalam satu senarai bernama
jumlah. Kedudukan jumlah markah adalah mengikut tertib.

#Mencari markah tertinggi dan terendah dalam senarai jumlah

tertinggi = max(jumlah)

terendah = min(jumlah) Senarai jumlah dihantar sebagai argumen kepada function max( ) dan

min( ). Function max( ) akan memulangkan markah tertinggi dan function
min( ) akan memulangkan markah terendah dalam senarai jumlah.

#Menggunakan sub-function untuk mencari indeks
indeks_tertinggi = jumlah.index(tertinggi)
indeks_terendah = jumlah.index(terendah)

Jumlah markah tertinggi dan terendah dihantar sebagai
argumen kepada sub-function index( ). Nombor indeks yang
dipulangkan disimpan dalam pemboleh ubah masing-masing.

#Menggunakan sub-function untuk mencari nama murid Nilai indeks yang disimpan dalam
murid_markah_tertinggi = nama[indeks_tertinggi] pemboleh ubah digunakan untuk
murid_markah_terendah = nama[indeks_terendah] mengesan nama murid yang mendapat
jumlah markah tertinggi dan terendah.

#Mencetak nama berserta markah tertinggi dan terendah
print(murid_markah_tertinggi, "memperoleh jumlah markah tertinggi, iaitu ", tertinggi)
print(murid_markah_terendah, "memperoleh jumlah markah terendah, iaitu ", terendah)

Rajah 4.45  Kod atur cara Contoh 4.8 Ln: 39 Col:0

171

Python 3.6.5 Shell

File Edit Shell Debug Options Window Help

====== RESTART: C:\Documents\Tutorial Python\Markah Min dan Mak.py ======
Chong Yee Ling memperoleh jumlah markah tertinggi, iaitu 334
Denish A/L Kathigasu memperoleh jumlah markah terendah, iaitu 276
>>>

Ln: 7 Col:4

Rajah 4.46  Output bagi kod atur cara Contoh 4.8

User-defined (ii) Function dihasilkan sendiri (user-defined)
function bahasa User-defined function ialah satu set arahan yang ditulis oleh
pengaturcaraan pengatur cara untuk melaksanakan suatu tugasan khas yang
Python akan berulang dalam atur cara utama. User-defined function
yang ditulis juga perlu mempunyai nama yang deskriptif,
goo.gl/sKay8F iaitu nama yang dapat mencerminkan tugasnya. Lazimnya,
user-defined function ditulis kerana ketiadaan built-in function
yang dapat memenuhi kehendak pengatur cara. Seperti built-in
function, user-defined function mampu menerima argumen dan
memulangkan nilai kepada atur cara yang memanggilnya.

4.9 Penggunaan user-defined function yang mengira kuasa dua dalam bahasa
pengaturcaraan Python.

kuasa_dua.py - C:\Documents\Tutorial Python\kuasa_dua.py (3.6.5)

File Edit Format Run Options Window Help User-defined function (kuasadua) ini:

# Fungsi yang mengira kuasa dua • Menerima nilai argumen yang dihantar dan
def kuasadua(x): menyimpannya dalam parameter x

return x*x • Mengira nilai x2
• Memulangkan hasil kiraan kepada pernyataan kod

# Bahagian utama atur cara yang meminta kiraan ini

# Minta pengguna memasukkan satu nombor

nom = int(input("Masukkan satu nombor integer: "))

# panggilan fungsi • Pernyataan kod ini memanggil function
nom_kuasa = kuasadua(nom) kuasadua dan menghantar nilai dalam
print("Kuasa dua bagi",nom,"ialah",nom_kuasa) pemboleh ubah nom kepadanya.

• Terima nilai yang dipulangkan oleh

function kuasadua dan umpukkan

kepada pemboleh ubah nom_kuasa.

Ln: 1 Col:0

Rajah 4.47  Kod atur cara Contoh 4.9

172

Struktur Kod Arahan 4.2

Python 3.6.5 Shell Ln: 11 Col:4

File Edit Shell Debug Options Window Help

======= RESTART: C:\Documents\Tutorial Python\kuasa_dua.py =======
Masukkan satu nombor integer: 2
Kuasa dua bagi 2 ialah 4
>>>
======= RESTART: C:\Documents\Tutorial Python\kuasa_dua.py =======
Masukkan satu nombor integer: 5
Kuasa dua bagi 5 ialah 25
>>>

Rajah 4.48  Output bagi kod atur cara Contoh 4.9

4.17

Nyatakan built-in function yang digunakan dalam bahagian utama atur cara dalam Contoh 4.9 yang
membolehkan pengguna memasukkan nombor.

4.10 Penggunaan user-defined function yang membandingkan dua nombor dalam
bahasa pengaturcaraan Python.

susun_nombor.py - C:\Documents\Tutorial Python\susun_nombor.py (3.6.5)

File Edit Format Run Options Window Help

""" User-defined function yang memulangkan nombor besar di kiri
dan nombor kecil di kanan """
def besar_kecil(x,y):

if x > y:
return x, y

else:
return y, x

# Bahagian utama atur cara
# Minta pengguna memasukkan dua nombor
a = int(input("Masukkan nombor integer yang pertama: "))
b = int(input("Masukkan nombor integer yang kedua: "))

# panggilan user-defined function
[besar, kecil] = besar_kecil(a,b)
print("Nombor",besar,"lebih besar daripada",kecil)

• Memanggil function besar_kecil serta menghantar dua nilai ke pemboleh ubah x dan y. Ln: 1 Col:0
• Nilai yang dipulangkan akan diumpukkan kepada senarai [besar, kecil].
• Nilai-nilai dipaparkan.

User-defined function ini:
• Menerima dua nilai argumen dan simpan dalam parameter x dan y
• Membandingkan dua nilai dalam parameter dan terbalikkan tempat jika y > x
• Memulangkan kedua-dua nilai mengikut susunan nombor lebih besar di kiri dan nombor lebih kecil di kanan

Rajah 4.49  Kod atur cara Contoh 4.10

173

Python 3.6.5 Shell

File Edit Shell Debug Options Window Help

====== RESTART: C:\Documents\Tutorial Python\susun_nombor.py ======

Masukkan nombor integer yang pertama: 6
Masukkan nombor integer yang kedua: 9
Nombor 9 lebih besar daripada 6
>>>

Ln: 8 Col:4

Rajah 4.50  Output bagi kod atur cara Contoh 4.10

Datang sekali Ditulis
dengan bahasa oleh pengatur
pengaturcaraan
cara

Perlu Mempunyai Boleh ada
argumen nama atau tanpa
argumen
(bahagian
pengepala)

Built-in Mempunyai User-defined
Function badan function Function
(set arahan)

Nama yang Mempunyai Boleh diberikan
unik, deskriptif, pernyataan sebarang nama yang
terpelihara dan tidak
boleh diubah return tidak bercanggah
dengan kata-kata
kunci dalam bahasa
pengaturcaraan

Kod sumber Kod sumber
tidak boleh boleh dilihat
dan diubah
dilihat

Rajah 4.51  Persamaan dan perbezaan antara built-in function dan user-defined function

174

Struktur Kod Arahan 4.2

4.8

Mengenal Pasti Function dan Procedure Kaedah
1. Kaji kod atur cara berikut, kenal pasti semua function Think-Pair-Share

dan procedure. py

Harga Tempahan Kek.py - C:\Documents\Tutorial Python\Harga Temp... goo.gl/wMqamQ

File Edit Format Run Options Window Help

jenis_kek = ["keju","mentega","pelangi","kopi"]
harga_kek = [40,35,35,30]
jumlah = [0,1,2,3]

a = int(input("Masukkan tempahan untuk kek keju: "))
b = int(input("Masukkan tempahan untuk kek mentega: "))
c = int(input("Masukkan tempahan untuk kek pelangi: "))
d = int(input("Masukkan tempahan untuk kek kopi: "))

tempahan = [a,b,c,d]

def jumlah_harga():
for i in range(4):
jumlah[i] = harga_kek[i] * tempahan[i]
return (jumlah)

def cetak():
print("\n\nTempahan anda ialah:")
print(a,"kek",jenis_kek[0])
print(b,"kek",jenis_kek[1])
print(c,"kek",jenis_kek[2])
print(d,"kek",jenis_kek[3])
print("\nJumlah harga untuk tempahan ialah RM",sum(jumlah))

jumlah_harga()
cetak()

Ln: 1 Col:0

2. Kenal pasti perkara berikut dan tulis pada sehelai kertas.
(a) Jenis dan fungsi built-in function
(b) User-defined function dan procedure serta tugasnya
(c) Output atur cara

3. Kongsikan idea bersama-sama ahli kumpulan anda. Bincangkan cara-cara untuk
menambah baik hasil dapatan anda.

4. Sediakan satu persembahan dan bentangkan hasil dapatan kumpulan anda di dalam
kelas.

175

Pembelajaran 4.2.3 Menulis Pernyataan Function dan
Procedure
Murid boleh:
4.2.3 M enulis pernyataan †† Function

function dan Penulisan user-defined function bermula dengan mentakrifkan
procedure function tersebut di permulaan atur cara. Selepas itu, pengguna
boleh memanggil fungsi tersebut setiap kali tugasan khas function
perlu dilaksanakan dalam atur cara. Berikut menunjukkan
sintaks pentakrifan suatu user-defined function.

Parameter digunakan def nama_function (parameter):
untuk:      badan function
1. Menerima dan      return (nilai)

menyimpan data yang Kata kunci def digunakan untuk mentakrifkan function.
dihantar kepadanya Nama sesuatu function harus mencerminkan tugas khas yang
semasa dipanggil akan dilakukannya. Parameter ialah pemboleh ubah untuk
2. Memulangkan data menerima argumen (nilai) yang dihantar kepada function semasa
kepada pernyataan dipanggil. Parameter dimasukkan dalam tanda kurungan ( ).
arahan, function, Pentakrifan nama function dan parameter mesti diakhiri dengan
procedure atau tanda titik bertindih.
atur cara lain yang
memanggilnya Badan function dimulakan sebaris selepas nama function dan
perlu inden dari jidar kiri. Badan function terdiri daripada set
arahan (instructions) bagi tugasnya. Perkataan return digunakan
untuk memulangkan nilai atau output yang dihasilkan oleh
function tersebut.

Dalam kebanyakan bahasa pengaturcaraan, pernyataan return dalam function
memulangkan satu nilai sahaja. Nilai ini boleh merupakan nilai tunggal atau satu ungkapan
yang menghasilkan satu nilai tunggal. Walau bagaimanapun, dalam bahasa pengaturcaraan
Python, nilai yang dipulangkan dalam pernyataan return function boleh berupa satu nilai
tunggal atau sekumpulan nilai yang diasingkan dengan tanda koma. Sebagai contoh,

Situasi 1: Pernyataan return
def hasiltambah (x,y): memulangkan satu nilai tunggal.
   jumlah = x + y Pernyataan return memulangkan satu nilai
  return (jumlah) tunggal dari ungkapan yang digunakan.
Situasi 2: Pernyataan return memulangkan lebih
def hasiltambah (x,y): daripada satu nilai. Pernyataan return ini
  return (x + y) memulangkan dua nilai dalam susunan menaik.
Situasi 3:
def susun_naik (x, y):
  if x > y:
    return (y, x)
  else:
    return (x, y)

176

Struktur Kod Arahan 4.2

4.11 Penggunaan user-defined function bagi simulasi permainan batu seremban.
Batu seremban ialah sejenis permainan tradisional yang dimainkan di Malaysia. Dalam
permainan ini, seorang pemain bermula dengan peringkat yang mudah sehingga ke peringkat
terakhir yang disebut buah lapan. Kemudian, barulah pemain melakukan aktiviti timbang
dan tangkap untuk mendapatkan mata.

ÆÆ

Lambung dan timbang batu Lambung dan tangkap batu

Rajah 4.52  Cara lambung dan timbang dan lambung dan tangkap batu
Dalam Contoh 4.11, simulasi aktiviti timbang dan tangkap dalam permainan boleh
diwujudkan dan nama user-defined function yang akan dibina dinamakan bilangan_batu( ).
User-defined function ini akan menerima satu nilai yang mewakili bilangan batu yang akan
digunakan dalam permainan, iaitu lima. Nilai ini akan dihantar ke sub-function bagi built-in
function random( ), iaitu random.randint( ). Nilai yang dipulangkan kali pertama adalah
bilangan batu yang berjaya ditimbang. Selepas itu, nilai ini dihantar ke function random.
randint( ) semula dan nilai yang dipulangkan kali kedua mewakili bilangan batu yang
berjaya ditangkap.

Batu Seremban.py - C:\Documents\Tutorial Python\Batu Seremban.py (3.6.5)
File Edit Format Run Options Window Help
import random

# User-defined function untuk simulasi menimbang batu

def bilangan_batu(x):

hasil =(random.randint(0,x))

return hasil

# Membuat panggilan function. Gelung while digunakan supaya
# Hantar nilai bilangan batu yang digunakan ke dalam bilangan_batu() aktiviti timbang dan tangkap
terus = "Y" dapat diteruskan sehingga

while terus == "Y": pemain menamatkan permainan.

hasil_timbang = bilangan_batu(5)

print("Hasil timbangan anda ialah " + str(hasil_timbang) + " batu.")

# Menangkap batu. Membuat panggilan fungsi. Sekiranya batu berjaya ditimbang,
# Hantar hasil timbangan ke dalam bilangan_batu() barulah user-defined function
bilangan_batu( ) dipanggil
if hasil_timbang > 0: semula. Kali ini argumen yang
tangkap = bilangan_batu(hasil_timbang)
print("Hasil tangkapan anda ialah " + str(tangkap)) dihantar ialah hasil_timbang dan

terus = input("\nTeruskan [Y] atau Berhenti [T]? Tekan [Y|T] ") nilai yang dipulangkan ialah bilangan
print("")
batu yang berjaya ditangkap.
Ln: 24 Col:0

Rajah 4.53  Kod atur cara Contoh 4.11

Panggilan function bilangan_batu diletakkan dalam gelung ulangan while supaya aktiviti
timbang dan tangkap batu dapat dilakukan secara berulangan.

177

Python 3.6.5 Shell

File Edit Shell Debug Options Window Help

===== RESTART: C:\Documents\Tutorial Python\Batu Seremban.py =====
Hasil timbangan anda ialah 1 batu.
Hasil tangkapan anda ialah 1

Teruskan [Y] atau Berhenti [T]? Tekan [Y|T] Y

Hasil timbangan anda ialah 2 batu.
Hasil tangkapan anda ialah 1

Teruskan [Y] atau Berhenti [T]? Tekan [Y|T] T

>>>

Ln: 25 Col:4

Rajah 4.54  Output bagi kod atur cara Contoh 4.11

4.9

Menulis Pernyataan Function Kaedah Brainstorming
Activity

Corak perbelanjaan murid sekolah di pesta buku:

Nama Buku RM Buku Anda ialah ahli jawatankuasa penganjur
murid cerita rujukan pesta buku. Anda ditugaskan untuk
Buku mendapatkan data-data mengenai:
Aini 12 latihan 33 (a) Jumlah bilangan buku yang dibeli
Aru
Lee 10 15 15 oleh murid sekolah;
(i) secara keseluruhan.
15 12 0 (ii) mengikut jenis bahan.
(b) Jenis bahan bacaan yang paling
18 disukai oleh murid sekolah.

1. Anda diberi masa untuk:
(a) Mengkaji situasi di atas dan meleraikan masalah
(b) Menyatakan tugas khas yang telah dikenal pasti
(c) Menulis pernyataan function bagi melakukan tugas khas yang telah dikenal pasti

2. Selepas tamat tempoh yang diberikan, anda dikehendaki berkumpul dalam
kumpulan. Kongsikan dan bincangkan hasil dapatan masing-masing bersama-sama
rakan sekumpulan.

3 Gunakan bahasa pengaturcaraan Python untuk mengekod dan menguji pernyataan
function yang dihasilkan.

178

Struktur Kod Arahan 4.2

†† Procedure Procedure
Sintaks untuk menulis procedure hampir serupa dengan dalam bahasa
sintaks pentakrifan user-defined function, cuma procedure tidak pengaturcaraan
memulangkan sebarang nilai (output) kembali kepada atur Python
cara atau pernyataan kod yang memanggilnya. Badan procedure
hanya terdiri daripada set arahan bagi tugas khas.

def nama_procedure (parameter): pynewbs.com/7a/a
     badan procedure

Kata kunci def digunakan untuk mentakrifkan procedure.
Nama sesuatu procedure harus mencerminkan tugas khas yang
akan dilakukannya. Jika mempunyai input atau parameter,
maka parameter perlu dinyatakan dalam tanda kurungan ( ).
Jika tidak, tanda kurungan dibiarkan kosong. Pentakrifan nama
procedure dengan atau tanpa parameter mesti diakhiri dengan
tanda titik bertindih.

Badan procedure dimulakan sebaris selepas nama procedure dan perlu inden dari jidar
kiri. Badan procedure terdiri daripada set arahan bagi melaksanakan tugasnya.

Setelah procedure siap dilaksanakan, pelaksanaan atur cara akan kembali semula ke baris
selepas pemanggilan procedure.

4.12 Penggunaan procedure untuk mencetak lirik lagu menggunakan bahasa
pengaturcaraan Python.

Aimah ialah seorang guru tadika dan kelasnya mempunyai 15 orang murid. Setiap bulan,
Aimah akan menyediakan lirik lagu “Selamat Hari Jadi” untuk murid-muridnya. Katakan
dua orang murid menyambut hari jadi pada bulan ini. Berikut menunjukkan satu segmen
kod atur cara yang akan mencetak lirik lagu “Selamat Hari Jadi” yang bernama tanpa
menggunakan procedure.

Hari Jadi Biasa.py - C:\Documents\Tutorial Python\Hari Jadi Biasa.py (3.6.5)

File Edit Format Run Options Window Help

# Mencetak lirik lagu "Selamat Hari Jadi untuk Ali"
print("Selamat hari jadi!")
print("Selamat hari jadi!")
print("Selamat hari jadi, Ali")
print("Selamat hari jadi!")
print()

# Mencetak lirik lagu "Selamat Hari Jadi untuk Raju"
print("Selamat hari jadi!")
print("Selamat hari jadi!")
print("Selamat hari jadi, Raju")
print("Selamat hari jadi!")
print()

Ln: 1 Col:0

Rajah 4.55  Kod atur cara Contoh 4.12

179

Python 3.6.5 Shell
File Edit Shell Debug Options Window Help
==== RESTART: C:\Documents\Tutorial Python\Hari Jadi Biasa.py ====
Selamat hari jadi!
Selamat hari jadi!
Selamat hari jadi, Ali
Selamat hari jadi!

Selamat hari jadi!
Selamat hari jadi!
Selamat hari jadi, Raju
Selamat hari jadi!

>>>

Ln: 15 Col:4

Rajah 4.56  Output bagi kod atur cara Contoh 4.12
Aimah mendapati lirik lagu tersebut adalah sama dan berulangan. Bayangkan jika Aimah
ingin mencetak lirik lagu untuk semua muridnya.
Penggunaan procedure lirik( ) dengan parameter boleh digunakan supaya seluruh lirik tidak
perlu ditaip berulang kali. Ini telah menjimatkan masa menaip, kejadian ralat berkurangan dan
segmen kod kelihatan lebih kemas. Berikut menunjukkan segmen kod yang telah ditambah
baik dengan penggunaan procedure untuk mencetak lirik lagu “Selamat Hari Jadi”.

Hari Jadi Procedure.py - C:\Documents\Tutorial Python\Hari Jadi Procedure.py (3.6.5)
File Edit Format Run Options Window Help

# Menggunakan procedure untuk lirik lagu
def lirik(nama):

print("Selamat hari jadi!")
print("Selamat hari jadi!")
print("Selamat hari jadi",nama)
print("Selamat hari jadi!")
print()

# Mencetak lirik lagu untuk pelajar
lirik("Ali")
lirik("Raju")

Ln: 12 Col:0

Rajah 4.57  Kod atur cara Contoh 4.12 yang menggunakan procedure
Setelah penggunaan procedure, hanya dua baris kod sahaja diperlukan oleh Aimah bagi
mencetak lirik lagu untuk murid-muridnya. Ini memudahkan pencetakan lirik lagu yang
seterusnya untuk murid-murid yang lain.

180

Struktur Kod Arahan 4.2

4.10 Kaedah
Gallery Walk
Menulis Pernyataan Procedure
1. Kaji segmen kod berikut. Tulis cadangan anda untuk meringkaskan py

kod di bawah dengan menggunakan procedure.

Lagu Chan Mali Chan.py - C:\Documents\Tutorial Python\Lagu Chan Mali... goo.gl/DzbwE3
File Edit Format Run Options Window Help

# Lirik Lagu Chan Mali Chan

print("Lirik Lagu Chan Mali Chan\n")

print("Di mana dia anak kambing saya?")
print("Anak kambing saya yang makan daun talas")
print("Di mana dia buah hati saya?")
print("Buah hati saya bagai telur dikupas\n")

print("Chan mali chan, chan mali chan")
print("Chan mali chan, ketipung payung")
print("Chan mali chan, chan mali chan")
print("Chan mali chan, ketipung payung\n")

print("Di mana dia anak kambing saya?")
print("Anak kambing saya yang makan daun talas")
print("Di mana dia buah hati saya?")
print("Buah hati saya bagai telur dikupas\n")

print("Chan mali chan, chan mali chan")
print("Chan mali chan, ketipung payung")
print("Chan mali chan, chan mali chan")
print("Chan mali chan, ketipung payung\n")

Ln: 27 Col:0

2. Pamerkan hasil kerja anda pada dinding kelas untuk dilihat oleh kumpulan lain.
3. Murid-murid digalakkan untuk menulis komen tentang hasil kerja kumpulan lain dan

menampalkannya di atas hasil kerja tersebut.
4. Guru akan memilih hasil kerja yang terbaik.
5. Gunakan procedure yang serupa, sediakan satu segmen kod Python untuk lagu

negeri anda. Anda digalakkan untuk menguji segmen kod anda menggunakan
perisian aplikasi Python.

181

Pembelajaran 4.2.4 Menulis Atur Cara yang Melibatkan
Function dan Procedure
Murid boleh:
4.2.4 M enghasilkan Anda telah mempelajari cara menulis pernyataan function dan
procedure di subtopik 4.2.3. Penggunaan function dan procedure
atur cara yang semasa penulisan kod untuk satu atur cara amat penting dan
melibatkan: wajib. Rajah 4.58 menunjukkan kepentingan penggunaan
(i) function function dan procedure.
(ii) procedure

Buku Internet

Dapat digunakan
secara terus atau

berulang kali
tanpa menulis

kodnya

Atur cara kelihatan Function Boleh diguna pakai
lebih teratur, dan dalam atur cara
lain sekirannya
kemas, bermodular Procedure
dan lebih mudah tugasan yang sama
difahami diperlukan

Memudahkan Mengurangkan
proses kemungkinan
berlakunya ralat
nyahpepijat Menjimatkan
Boleh masa

dikongsikan

Guru Komuniti pengatur cara
Rajah 4.58 Kepentingan function dan procedure dalam penghasilan atur cara

182

Struktur Kod Arahan 4.2

4.13 Menghasilkan satu atur cara kalkulator yang
melibatkan gabungan function dan procedure.

Guru meminta anda menghasilkan satu atur cara kalkulator yang
dapat melakukan empat operasi asas, iaitu tambah, tolak, darab
dan bahagi terhadap dua nombor integer yang dimasukkan oleh
pengguna atur cara.

Bagi menyelesaikan masalah ini, anda perlu mengaplikasikan
konsep pemikiran komputasional dalam fasa-fasa pembangunan
atur cara. Output yang dikehendaki adalah seperti berikut:

Menu Kalkulator Fasa-fasa pembangunan
1. Tambah atur cara.
2. Tolak
3. Darab Analisis Masalah
4. Bahagi Reka Bentuk
5. Tamat Atur Cara
Pengekodan
Pilihan anda [1 hingga 5]: 3
Masukkan nombor pertama : 4
Masukkan nombor kedua : 5
Output: 4 × 5 = 20
Terima kasih kerana menggunakan saya.

Fasa Analisis Masalah Pengujian dan
Penyahpepijatan

1. Mengenal pasti masalah: Membina atur cara yang boleh Dokumentasi
melaksanakan empat operasi.

2. Mengenal pasti input, proses dan output:
(a) Input: Pilihan operasi dari menu kalkulator dan
memasukkan dua nombor.
(b) Proses: Lakukan operasi yang dipilih.
(c) Output: Paparkan jawapan bagi dua nombor yang
dimasukkan berdasarkan operasi yang dipilih.

Fasa Reka Bentuk Atur Cara

1. Membangunkan algoritma bagi tugas-tugas kecil (sub-task). 4.18
2. Menulis pseudokod.
3. Melakar carta alir. Apakah teknik-teknik
4. Mereka bentuk antara muka pengguna untuk input dan pemikiran komputasional
yang digunakan semasa
output data. fasa analisis masalah?

183

Pseudokod

1 Mula
2 Isytihar pemboleh ubah aktif, pilihan, nombor1, nombor2, hasil
3 Setkan aktif = 1
4 Selagi aktif == 1
4.1 Papar menu berikut:
Kalkulator Bermenu
1. Tambah
2. Tolak
3. Darab
4. Bahagi
5. Tamat
4.2 Papar mesej “Pilihan anda [1 hingga 5]:”
4.3 Setkan pilihan = nombor yang dimasukkan
4.4 Jika pilihan == 1

4.4.1 Papar mesej “Masukkan nombor pertama:”
4.4.2 Setkan pertama = nombor yang dimasukkan
4.4.3 Papar mesej “Masukkan nombor kedua:”
4.4.4 Setkan kedua = nombor yang dimasukkan
4.4.5 Kira hasil = pertama + kedua
4.4.6 Papar “Output: nilai pertama + nilai kedua = hasil”
4.5 Jika pilihan == 2
4.5.1 Papar mesej “Masukkan nombor pertama:”
4.5.2 Setkan pertama = nombor yang dimasukkan
4.5.3 Papar mesej “Masukkan nombor kedua:”
4.5.4 Setkan kedua = nombor yang dimasukkan
4.5.5 Kira hasil = pertama - kedua
4.5.6 Papar “Output: nilai pertama - nilai kedua = hasil”
4.6 Jika pilihan == 3
4.6.1 Papar mesej “Masukkan nombor pertama:”
4.6.2 Setkan pertama = nombor yang dimasukkan
4.6.3 Papar mesej “Masukkan nombor kedua:”
4.6.4 Setkan kedua = nombor yang dimasukkan
4.6.5 Kira hasil = pertama * kedua
4.6.6 Papar “Output: nilai pertama x nilai kedua = hasil”
4.7 Jika pilihan == 4
4.7.1 Papar mesej “Masukkan nombor pertama:”
4.7.2 Setkan pertama = nombor yang dimasukkan
4.7.3 Papar mesej “Masukkan nombor kedua:”
4.7.4 Setkan kedua = nombor yang dimasukkan
4.7.5 Kira hasil = pertama / kedua
4.7.6 Papar “Output: nilai pertama / nilai kedua = hasil”
4.8 Jika pilihan == 5
4.8.1 Setkan aktif = 0
5 Papar mesej “Terima kasih kerana menggunakan saya.”
6 Tamat

Petunjuk:
Biru – Set pernyataan ini diasingkan dan dijadikan satu subpseudokod dptDuaNombor.
Ungu – Set pernyataan ini diasingkan dan dijadikan satu subpseudokod kiraCetak.
Hijau – Set pernyataan ini diasingkan dan dijadikan satu subpseudokod menu.
Kelabu – Set pernyataan ini diasingkan dan dijadikan satu subpseudokod dptPilihanPengguna.

184

Struktur Kod Arahan 4.2

Pseudokod yang Dimurnikan Melalui Pengaplikasian Pemikiran Komputasional
Pseudokod berikut adalah lebih tersusun, padat, kemas dan bermodular.

menu dptPilihanPengguna
1 Mula 1 Mula
2 Papar “Kalkulator 2 Setkan noPilihan = 0
3 Selagi noPilihan tidak dalam lingkungan 1
Bermenu”
3 Papar “1.  Tambah” dan 5
4 Papar “2.  Tolak” 3.1 Papar “Pilihan anda [1 hingga 5] :”
5 Papar “3.  Darab” 3.2 Setkan noPilihan = nombor yang ditaip
6 Papar “4.  Bahagi” 4 Tamat
7 Papar “5.  Tamat”
8 Tamat

Pseudokod Utama
1 Mula
2 Setkan aktif = 1
3 Selagi aktif == 1
3.1 Panggil menu
3.2 Setkan jenisOperasi = panggil dptPilihanPengguna
3.3 Jika jenisOperasi == 5
3.3.1 Setkan aktif = 0
3.4 Jika tidak
3.4.1 Setkan nom1 dan nom2 = panggil dptDuaNombor
3.4.2 Panggil kiraCetak (nom1, nom2)
3.5 Tamat jika
4 Papar “Terima kasih kerana menggunakan saya.”
5 Tamat

kiraCetak (a, b) dptDuaNombor
1 Mula 1 Mula
2 Jika jenisOperator == 1 2 Papar “Masukkan nombor
2.1 Kira hasiltambah = a + b
2.2  Papar “Output: a + b = pertama: ”
3 Setkan nombor1 = nombor
hasiltambah”
3 Lain jika jenisOperator == 2 yang dimasukkan
3.1 Kira hasiltolak = a - b 4 Papar “Masukkan nombor
3.2 P apar “Output: a - b =
kedua: ”
hasiltolak” 5 Setkan nombor2 = nombor
4 Lain jika jenisOperator == 3
4.1 Kira hasildarab = a × b yang dimasukkan
4.2 P apar “Output: a × b = 6 Pulangkan nombor1 dan

hasildarab” nombor2
5 Lain jika jenisOperator == 4 7 Tamat
5.1 Kira hasilbahagi = a ÷ b
5.2  Papar “Output: a / b = 185

hasilbahagi”
6 Tamat jika
7 Tamat

4.19 Fasa Pengekodan

Apakah teknik pemikiran Semasa fasa pengekodan, anda perlu mengenal pasti penulisan
komputasional yang sintaks-sintaks bagi function, procedure, input, proses dan output.
digunakan semasa fasa Selain itu, anda juga perlu mengenal pasti jenis
pengekodan? data input yang harus digunakan. py

goo.gl/onbYbT

Kalkulator Bermenu_2.py - C:\Documents\Tutorial Python\Kalkulator Bermenu_2.py (3.6.5)

File Edit Format Run Options Window Help

# Procedure menu()
def menu():

print("Kalkulator Bermenu")
print("1. Tambah")
print("2. Tolak")
print("3. Darab")
print("4. Bahagi")
print("5. Tamat")

# Function dptPilihanPengguna()
def dptPilihanPengguna():

noPilihan = 0
while (noPilihan < 1) or (noPilihan > 5):

noPilihan = int(input("Pilihan anda [1 hingga 5]: "))
return noPilihan

# Function dptDuaNombor()
def dptDuaNombor():

nombor1 = int(input("Masukkan nombor pertama : "))
nombor2 = int(input("Masukkan nombor kedua : "))
return nombor1, nombor2

# Procedure kiraCetak()
def kiraCetak(jenisOperator, a, b):

if jenisOperator == 1:
print("Output: " + str(a) + " + " + str(b) + " = " + str(a + b) +"\n")

elif jenisOperator == 2:
print("Output: " + str(a) + " - " + str(b) + " = " + str(a - b) +"\n")

elif jenisOperator == 3:
print("Output: " + str(a) + " * " + str(b) + " = " + str(a * b) +"\n")

elif jenisOperator == 4:
print("Output: " + str(a) + " / " + str(b) + " = " + str(a / b) +"\n")

# main ----------------------------------------------------------------------------
aktif = 1
while aktif == 1:

menu()
jenisOperasi = dptPilihanPengguna()
if jenisOperasi == 5:

aktif = 0
else:

[nom1, nom2] = dptDuaNombor()
kiraCetak(jenisOperasi, nom1, nom2)
print("Terima kasih kerana menggunakan saya.")

# ---------------------------------------------------------------------------------

Ln: 47 Col:0

Rajah 4.59  Kod atur cara Contoh 4.13

186

Struktur Kod Arahan 4.2

Python 3.6.5 Shell Ln: 59 Col:4 Imbas QR code ini
untuk menonton
File Edit Shell Debug Options Window Help video carta alir
bagi atur cara
== RESTART: C:\Documents\Tutorial Python\Kalkulator Kalkulator
Bermenu_2.py == Bermenu.
Kalkulator Bermenu
1. Tambah goo.gl/otCmBc
2. Tolak
3. Darab 4.20
4. Bahagi
5. Tamat 1. Apakah teknik
Pilihan anda [1 hingga 5]: 1 pemikiran
Masukkan nombor pertama : 4 komputasional yang
Masukkan nombor kedua : 7 digunakan untuk
Output: 4 + 7 = 11 mengenal pasti corak
yang berulangan di
Kalkulator Bermenu dalam pseudokod?
1. Tambah
2. Tolak 2. Apakah teknik
3. Darab pemikiran
4. Bahagi komputasional yang
5. Tamat digunakan untuk
Pilihan anda [1 hingga 5]: 2 mengenal pasti
Masukkan nombor pertama : 6 persamaan antara
Masukkan nombor kedua : 2 empat pernyataan
Output: 6 - 2 = 4 dalam subpseudokod
KiraCetak?
Kalkulator Bermenu
1. Tambah
2. Tolak
3. Darab
4. Bahagi
5. Tamat
Pilihan anda [1 hingga 5]: 3
Masukkan nombor pertama : 3
Masukkan nombor kedua : 9
Output: 3 * 9 = 27

Kalkulator Bermenu
1. Tambah
2. Tolak
3. Darab
4. Bahagi
5. Tamat
Pilihan anda [1 hingga 5]: 4
Masukkan nombor pertama : 3
Masukkan nombor kedua : 5
Output: 3 / 5 = 0.6

Kalkulator Bermenu
1. Tambah
2. Tolak
3. Darab
4. Bahagi
5. Tamat
Pilihan anda [1 hingga 5]: 5
Terima kasih kerana menggunakan saya.
>>>

Rajah 4.60  Output kod atur cara Contoh 4.13

187

4.11

Menambahkan Operasi Kuasa dan Punca Kuasa untuk Kalkulator Bermenu
1. Perhatikan Contoh 4.13.
2. Anda perlu menambah operasi kuasa dan punca kuasa n bagi suatu nombor bulat di

mana n ialah suatu integer positif.
3. Berdasarkan pseudokod di halaman 184, tambahkan operasi kuasa dan punca kuasa.

Tuliskan pseudokod baharu anda di atas kertas.
4. Dalam kumpulan, kongsikan hasil pseudokod masing-masing dan bincangkan

bersama-sama untuk menghasilkan satu pseudokod yang terbaik.
5. Muat turun fail Kalkulator Bermenu_2.py dari goo.gl/onbYbT. Kemudian,

lancarkan perisian aplikasi Python untuk menambahkan kod yang diperlukan
bagi menambahkan operasi kuasa dan punca kuasa. Simpan fail baharu ini
dengan nama Kalkulator Bermenu Baharu.py.

4.7

Membangunkan Satu Atur Cara yang Mengandungi Function dan Procedure

*********************************** Imbas Kembali
Menu Mengira Isi padu Isi padu kuboid = panjang  lebar  tinggi
Isi padu silinder = luas tapak  tinggi;
*********************************** luas tapak = π  jejari  jejari
1. Kuboid Isi padu kon = 1/3  luas tapak  tinggi;
2. Silinder luas tapak = π  jejari  jejari
3. Kon Isi padu sfera = 4/3  π  jejari  jejari  jejari;
4. Sfera π ialah 22/7 atau 3.142
***********************************
Masukkan pilihan anda: [1 – 4] :

Sekiranya pilihan ialah 2, maka paparan berikut Sekiranya pilihan ialah 4, maka paparan berikut
akan muncul: akan muncul:
Masukkan jejari : 3 Masukkan jejari : 3
Masukkan tinggi : 21 Isi padu ialah 113.112
Isi padu ialah 593.838

Bangunkan satu atur cara yang mengira isi padu kuboid, silinder, kon dan sfera dengan
menggunakan langkah-langkah di bawah:
1. Tuliskan satu procedure untuk mencetak Menu Mengira Isi padu.
2. Bagi setiap bentuk geometri, tuliskan satu function khusus untuk mengira isi padunya.
3. Tuliskan satu atur cara utama yang mengabungkan procedure dan semua function yang

telah dibina untuk membolehkan pengguna mengira isi padu bentuk geometri pilihannya.
4. Cadangkan cara bagaimana anda memurnikan atur cara yang dibina dalam langkah

3 agar atur cara itu boleh digunakan berkali-kali sehingga pengguna memilih untuk
menamatkannya.

188

Struktur Kod Arahan 4.2

4.2.5 Menguji Atur Cara dan Membaiki Ralat Pembelajaran

Menguji dan membaiki ralat ialah satu fasa penting dalam Murid boleh:
pembangunan atur cara. Atur cara yang baik harus bebas ralat. 4.2.5  Menguji atur cara
Ralat pengaturcaraan dinamakan pepijat (bugs) dan proses
menjejaki ralat ini disebut sebagai nyahpepijat (debugging). Ralat dan membaiki ralat
dalam pengaturcaraan boleh dibahagikan kepada tiga kategori, pada atur cara yang
iaitu ralat sintaks (syntax error), ralat masa larian (runtime error) dihasilkan.
dan ralat logik (logic error).

4.21

Nyatakan kaedah-kaedah yang telah anda gunakan semasa di Tingkatan 1 dan Tingkatan 2 untuk
menguji atur cara.

Kini, kita perlu menguji bukan
sahaja atur cara utama tetapi
juga function dan procedure
yang digunakan.

Bukankah menguji atur Ya, itu betul tetapi atur cara yang
cara dan membaiki ralat dibangunkan kali ini mengandungi
telah kita belajar semasa function dan procedure. Jadi, proses
di Tingkatan 2? menguji dan nyahpepijat sesuatu
function dan procedure dapat
dilakukan walaupun atur cara utama
masih belum disempurnakan.

189

Ralat sintaks

Setiap bahasa pengaturcaraan mempunyai set tatabahasa, hukum dan peraturan yang
mengawal cara penggunaan bahasa tersebut. Kesemua ini dikenali sebagai sintaks kepada bahasa
pengaturcaraan. Sintaks yang difahami oleh penterjemah C dan Python adalah berlainan.

Jadual 4.12 menunjukkan format penulisan sintaks bagi struktur pilihan kedua-dua
bahasa C dan Python yang berlainan. Struktur pilihan bahasa Python mempunyai kata kunci
elif yang hanya boleh difahami oleh penterjemah Python dan setiap kata kuncinya diakhiri
dengan tanda ‘ : ’. Selain itu, bahasa Python tidak menggunakan simbol { } walaupun blok
arahan mengandungi lebih daripada satu pernyataan dan setiap arahan tidak diakhiri dengan
tanda ‘ : ’. Hanya setiap baris yang bermula dengan kata kunci diakhiri dengan tanda ‘ : ’.

Jadual 4.12  Sintaks bagi keratan atur cara dalam bahasa C dan Python

Bahasa C Bahasa Python
if (a== b)  { if (a== b) :
  pernyataan1;   pernyataan1
  pernyataan2; }   pernyataan2
else if (a > b) elif (a > b) :
  pernyataan3;   pernyataan3
else else :
  pernyataan4;   pernyataan4

Sekiranya satu baris kod arahan yang ditulis itu tidak menepati laras bahasa pengaturcaraan
yang digunakan, maka baris kod arahan itu bukan sahaja tidak dapat difahami oleh
penterjemah bahasa tersebut bahkan tidak dapat dilaksanakan. Ralat ini dikenali sebagai
ralat sintaks. Ralat ini sering berlaku kerana kecuaian pengatur cara semasa menaip kod
arahan. Jujukan pelaksanaan (execution) arahan dalam function atau procedure akan terhenti
pada baris kod arahan yang mempunyai ralat dan mesej ralat akan dipaparkan.

4.14 Pengesanan ralat sintaks dalam procedure oleh penterjemah Python.

Jadual 4.13 menunjukkan kod procedure ulang( ) yang mempunyai ralat sintaks. Pelaksanaan
arahan dalam procedure ini akan terhenti pada penghujung baris yang ditandakan dengan ”
oleh penterjemah Python. Tetingkap SyntaxError akan dipaparkan dengan penjelasan ralat
yang berlaku dan cadangan membaikinya.

Jadual 4.13

Paparan kod procedure yang mempunyai Paparan mesej ralat sintaks
ralat sintaks
SyntaxError
Ralat Sintaks.py - C:\Documents\... Missing parentheses in call to ‘print’. Did you mean
File Edit Format Run Options Window Help print(“Cetak teks anda.”)?
def ulang():
OK
for i in range (3):
print "Cetak teks anda."

Ln: 5 Col:0

190


Click to View FlipBook Version