Selasa, 20 Februari 2018

Materi tentang MySQL(PPL)


1. Pengertian MySQL

MySQL adalah multiuser database yang menggunakan bahasa structured query language ( SQL ). MySQL dalam operasi client-server melibatkan serverdaemon MySQL disisi server dan berbagai macam program serta library yang berjalan disisi client.
Dalam bahasa SQL pada umumnya informasi tersimpan dalam table - tabel yang secara logic merupakan struktur dua dimensi terdiri dari baris ( row atau record ) dan kolom (column atau field ). Sedangkan dalam sebuah database dapat terdiri dari beberapa tabel.
Pada saat ini, pengelolaan database dengan menggunakan berbagai jenis perangkat lunak sudah mempengaruhi kehidupan masyarakat modern. Hal tersebut dapat dilihat dari kegiatan sehari - hari yang tidak terlepas dari penggunaan database dengan menggunakan DBMS ( DataBase Management System ).
Manajemen data adalah sekumpulan berbagai disiplin ilmu yang berkaitan untuk mengelola data sehingga menjadi sumberdaya yang sangat bernilai. Sumberdaya manajemen data adalah pengembangan dan eksekusi dari arsitektur database, kebijakan, pelatihan dan prosedur yang dikelola secara baik dan secara menyeluruh untuk kepentingan  manajemen data ini adalah :

1. Database         : Kumpulan data yang saling berhubungan secara logic, dirancang untuk memenuhi kebutuhan akan informasi banyak pengguna.

2. Table               : Baris-baris data yang berada dalam satu atau lebih kolom.

3. Field                : Merupakan kolom yang terdapat di dalam tabel atau disebut juga attribute.

4. Record            : Data yang berada didalamdatabase tersebut.

5. Tuple               : Suatu baris dari suatu relasi.

 2. Sejarah SQL
 SQL dimulai dari artikel seorang peneliti dari IBM bernama EF Codd yang membahas tentang ide pembuatan basis data relasiona l pada bulan Juni 1970. Artikel ini juga membahas kemungkinan pembuatan bahasa standar untuk mengakses data dalam basisdata tersebut. Bahasa tersebut kemudian diberi nama SEQUEL ( Structured EnglishQuery Language ).
Setelah terbitnya artikel tersebut, IBM mengadakan proyek pembuatan basis data relasional berbasis bahasa SEQUEL. Akan tetapi, karena permasalahan hukum mengenai penamaan SEQUEL, IBM pun mengubahnya menjadiSQL .
Implementasi basis data relasional dikenal dengan System/R .Di akhir tahun1970- an, muncul perusahaan bernama Oracle yang membuat server basis data popular yang bernama sama dengan nama perusahaannya.
Dengan naiknya kepopuleran Oracle maka SQL juga ikut populer sehingga saat ini menjadi standar de facto bahasa dalam manajemen basis data. Standarisasi SQL dimulai pada tahun 1986 ditandai dengan dikeluarkannya standar SQL oleh ANSI. Standar ini sering disebut dengan SQL86.
Standar tersebut kemudian diperbaiki pada tahun 1989 kemudian diperbaiki lagi padatahun 1992. Versi terakhir dikenal dengan SQL92 . Pada tahun 1999 dikeluarkanstandar baru yaitu SQL99 atau disebut juga SQL99, akan tetapi kebanyakan mplementasi mereferensi pada SQL92. Saat ini sebenarnya tidak ada server basis data yang 100% mendukung SQL92. Hal ini disebabkan masing - masing server memiliki dialek masing-masing.

3. Kelebihan MySQL
  • Multiplatform dan portable. 
MySQL dapat berjalan stabil pada berbagai sistemoperasi seperti Windows, Linux, FreeBSD, Mac Os X Server, Solaris, Amiga, dan masih banyak lagi.

  • Perangkat lunak sumber terbuka.
MySQL di distribusikan sebagai perangkat lunak sumber terbuka, dibawah lisensi GPL sehingga dapat digunakan secara gratis.

  • Multi-user.
MySQL dapat digunakan oleh beberapa pengguna dalam waktu yang bersamaan tanpa mengalami masalah atau konflik.

  • Performance Tuning.
MySQL memiliki kecepatan yang menakjubkan dalam menangani query sederhana, dengan kata lain dapat memproses lebih banyak SQL persatuan waktu.

  • Ragam tipe data.
MySQL memiliki ragam tipe data yang sangat kaya, seperti signed atau unsigned integer, float, double, char, text, date, timestamp, dan lain-lain.

  • Perintah dan Fungsi.
MySQL memiliki operator dan fungsi secara penuh yang mendukung perintah Select dan Where dalam perintah ( query ).

  • Keamanan.
MySQL memiliki beberapa lapisan keamanan seperti level subnetmask, nama host, dan izin akses user dengan sistem perizinan yang mendetail serta sandi terenkripsi.

  • Skalabilitas dan Pembatasan.
MySQL mampu menangani database dalam skala besar, dengan jumlah rekaman ( records ) lebih dari 50 juta dan 60 ribu tabel serta 5 milyarbaris. Selain itu batas indeks yang dapat ditampung mencapai 32 indeks pada tiap tabelnya.

  •   Konektivitas.
MySQL dapat melakukan koneksi dengan klien menggunakan protokolTCP / IP, Unix soket ( UNIX ), atau Named Pipes ( NT ).

  • Lokalisasi.
MySQL dapat mendeteksi pesan kesalahan pada klien dengan menggunakan lebih dari 20 bahasa. Meskipun demikian, bahasa Indonesia belum termasuk di dalamnya.

  • Antar Muka.
MySQL memiliki antar muka ( interface ) terhadap berbagai aplikasi dan bahasa pemrograman dengan menggunakan fungsi API ( Application Programming Interface ).

  • Klien dan Peralatan.
MySQL dilengkapi dengan berbagai peralatan ( tool ) yang dapat digunakan untuk administrasi database, dan pada setiap peralatan yang ada disertakan petunjuk online.

  • Struktur tabel.
MySQL memiliki struktur tabel yang lebih fleksibel dalam menangani ALTER TABLE dibandingkan database lainnya semacam PostgreSQL ataupun Oracle.

  • Memiliki lebih banyak type data
seperti : signed / unsigned integer yang memilikipanjang data sebesar 1,2,3,4 dan 8 byte, FLOAT, DOUBLE, CHAR, VARCHAR, TEXT, BLOB, DATE, TIME, DATETIME, TIMESTAMP, YEAR, SET dan tipeENUM.


4.     Kekurangan MySQL

  •   Untuk koneksi ke bahasa pemrograman visual seperti vb, delphi, dan foxpro, MySQL kurang support, karena koneksi ini menyebabkan field yang dibaca harus sesuai dengan koneksi dari program visual tersebut, dan ini yang menyebabkan MySQL jarang dipakai dalam program visual.

  •   Data yang ditangani belum begitu besar.

  • Kelemahan MySQL dari dulu sampai sekarang itu adalah 'feature-creep', artinya MySQL berusaha kompatibel dengan beberapa standard serta berusaha memenuhinya.
 
5.Pemakaian Dasar 
Secara umum, SQL terdiri dari dua bahasa, yaitu Data Definition Language ( DDL ) dan Data Manipulation Language (DML). Implementasi DDL dan DML berbeda untuk tiap sistem manajemen basis data (SMBD). Namun secara umum implementasi tiap bahasa ini memiliki bentuk standar yang ditetapkan ANSI. Artikel ini akan menggunakan bentuk paling umum yang dapat digunakan pada kebanyakan SMBD.

6.Perintah Dasar MySQL dengan Menggunakan Query Select
o Select Version.
Perintah query tersebut dipergunakan untuk menampilkan server versi MySQL.
o Select Current_Date.
Perintah query tersebut dipergunakan untuk menampilkan tanggal saat ini.
o Select Now.
Perintah query tersebut dipergunakan untuk menampilkan tanggal dan jam saat ini
o Select User.
Perintah tersebut dipergunakan untuk mengetahui nama user yang bersangkutan dannama client tempat user melakukan login. Dalam contoh di atas user yangmelakukan login adalah root dan login melalui komputer lokal server MySQL ( localhost ).
o Select Status.
Perintah query ini tidak digunakan dalam MySQL / menampilkan pesan error saat dijalankan.
o Status
Perintah query ini digunakan untuk menampilkan status MySQL yang sedang digunakan.
o Help.
Perintah query ini digunakan untuk menampilkan perintah - perintah dos yang ada pada MySQL.
o Select (*,/,-,+).
Perintah query ini digunakan untuk operasi aritmatik ( kali, bagi, kurang dan tambah ).
o Select SIN.
Perintah query ini digunakan untuk operasi dalam matematika yang mengubah angka menjadi derajat Sinus.
o Select COS.
Perintah query ini digunakan untuk operasi dalam matematika yang mengubah angka menjadi derajat Cosinus.
o Select TAN.
Perintah query ini digunakan untuk operasi dalam matematika yang mengubah angka menjadi derajat Tangen.
o Select Least.
Fungsi Least digunakan untuk mendapatkan nilai terkecil dari sederetan bilangan atau data yang ada. Seberapapun jumlah bilangan atau data yang ada, fungsi Leasttetap akan mendapatkan nilai terkecil.
o Select Greatest.
Fungsi Greatest digunakan untuk mendapatkan nilai terbesar dari sederetan datayang ada.
o Select ABS.
Perintah query ini digunakan untuk mengubah setiap bilangan negatif menjadi bilangan positif.
o Select MOD.
Perintah query ini digunakan untuk menampilkan sisa hasil bagi1.
o Select POW.
Perintah query ini digunakan untuk memangkatkan bilangan.

 7. Elemen SQL
Elemen dari SQL yang paling dasar antara lain pernyataan, nama, tipe data, ekspresi, konstanta dan fungsi bawaan.
o Pernyataan
Perintah dari SQL yang digunakan untuk meminta sebuah tindakan kepada DBMS. Pernyataan dasar SQL antara lain :
- ALTER                   : Merubah struktur tabel
- COMMIT              : Mengakhiri eksekusi transaksi
- CREATE                : Membuat tabel, indeks
- DELETE                 : Menghapus baris pada sebuah tabel
- DROP                    : Menghapus tabel, indeks
- GRANT                  : Menugaskan hak terhadap basis data kepada user
- INSERT                  : Menambah baris pada tabel
- REVOKE                : Membatalkan hak kepada basis data
- ROLLBACK            : Mengembalikan pada keadaan semula apabila transaksi gagal
- SELECT                  : Memilih baris dan kolom pada sebuah tabel
- UPDATE                : Mengubah value pada baris sebuah table

o Nama
Nama digunakan sebagai identitas, yaitu identitas bagi objek pada DBMS. Misal : tabel, kolom dan penggun

o Tipe data
Tipe data yang ada dalam MYSQL    :

1.Tipe data numerik antara lain        :
- TINYINT                     : Nilai integer yang sangat kecil.
- SMALLINT                 : Nilai integer yang kecil.
- MEDIUMINT             : Nilai integer yang sedang.
- INT                             : Nilai integer dengan nilai standar
- BEGINT                      : Nilai integer dengan nilai besar.
- FLOAT                        : Bilangan decimal dengan single-precission.
- DOUBLE                     : Bilangan decimal dengan double-precission.
- DECIMAL(M,D)         : Bilangan float yang dinyatakan sebagai string.
M : jumlah digit yang disimpan,
D : jumlah angka dibelakang koma.

2.Tipe data String antara lain           :
- CHAR                         : Karakter yang memiliki panjang tetap yaitu sebanyakn
- VARCHAR                 : Karakter yang memiliki panjang tidak tetap yaitu maksimum
- TINYBLOB                 : BLOB dengan ukuran sangat kecil
- BLOB                         : BLOB yang memiliki ukuran kecil
- MEDIUMBLOB         : BLOB yang memiliki ukuran sedang
- LONGBLOB               : BLOB yang memiliki ukuran besar
- TINYTEXT                  : teks dengan ukuran sangat kecil
- TEXT                          : teks yang memiliki ukuran kecil
- MEDIUMTEXT          : teks yang memiliki ukuran sedang
- LONGTEXT                : teks yang memiliki ukuran besar
- ENUM                        : kolom diisi dengan satu member enumerasi
- SET                             : Kolom dapat diisi dengan beberapa nilai anggota Himpunan

3. Tipe data tunggal dan jam                        :
- DATE                         : date memiliki format tahun-bulan-tanggal
- TIME                          : time memiliki format jam-menit-detik
- DATETIME                : gabungan dari format date dan time

o Ekspresi
Ekspresi digunakan untuk menghasilkan/menghitung nilai. Misalnya : jumlah=harga-diskon. Ekspresi aritmatika antara lain :
1.      +  : tambah
2.      –  : kurang
3.      /  : bagi
4.      *  : kali
o Konstanta
Nilai yang tetap

o Fungsi bawaan
Fungsi adalah subprogram yang dapat menghasilkan suatu nilai apabila fungsi tersebut dipanggil. Fungsi Agregat adalah fungsi yang digunakan untuk melakukan summary, statistik yang dilakukan pada suatu tabel/query.
- AVG(ekspresi)     : digunakan untuk mencari nilai rata-rata dalam kolom dari tabel.
- COUNT(x)             : digunakan untuk menghitung jumlah baris dari sebuah kolom dari tabel
- MAX(ekspresi)     : digunakan untuk mencari nilai yang paling besar dari suatu kolom dari tabel
- MIN(ekspresi)      : digunakan untuk mencari nilai yang paling kecil dari suatu kolom dari tabel
- SUM(ekspresi)     : digunakan untuk mengitung jumlah keseluruhan dari suatu kolom dari table

8. Pengantar Sintak Dasar Mysql

MySQL merupakan bahasa pemograman database di mana penulisan sintaknya tidak serumit bahasa pemograman lainnya seperti java, C++ dan sebagainya. Satu hal yang perlu diingat bahwa setiap penulisan script MySQL di Dos-Prompt harus selalu diakhiri dengan tanda titik koma (;).
Di dalam source MySQL yang telah terinstal secara default telah terisi sebuah database yang bernama mysql dan tes . Untuk dapat menampilkan apa saja nama database yang telah ada maupun yang akan kita buat, gunakan sintak :

Mysql> show databases;
Perhatikan contoh di bawah ini

Microsoft Windows [Version 6.1.7600]
Copyright (c) 2009 Microsoft Corporation.  All rights reserved.
C:\Users\Fyrman>cd..\..
C:\>cd/xampp/mysql/bin
C:\xampp\mysql\bin>mysql -u root –p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.5.16 MySQL Community Server (GPL)
Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| cdcol              |
| firman             |
| kampus             |
| mysql              |
| performance_schema |
| perpustakaan       |
| perpustakaan2      |
| perpustakaan_gaul  |
| phpmyadmin         |
| rental             |
| rental_cd          |
| test               |
| webauth            |
+--------------------+
14 rows in set (0.11 sec)
mysql>

Contoh di atas menunjukkan bahwa dengan menggunakan sintak show databases; berarti kita dapat menampilkan seluruh nama database yang telah ada. Sintak untuk bisa masuk kedalam salah satu system database tersebut adalah :
mysql> show databases;

+--------------------+
| Database           |
+--------------------+
| information_schema |
| cdcol              |
| firman             |
| kampus             |
| mysql              |
| performance_schema |
| perpustakaan       |
| perpustakaan2      |
| perpustakaan_gaul  |
| phpmyadmin         |
| rental             |
| rental_cd          |
| test               |
| webauth            |
+--------------------+
14 rows in set (0.11 sec)
mysql> use perpustakaan;
Database changed
mysql>

Dengan mengetikkan sintak use mysql; dan keluar kalimat database change, berarti kita telah masuk ke dalam database mysql yang telah ada. Di setiap database tentu ada terdapat beberapa table yang menjadi komponen dasar sebuah database. Sintak untuk menampilkan seluruh table yang telah ada di dalam database mysql adalah :

mysql> use perpustakaan;
Database changed
mysql> show tables;
+------------------------+
| Tables_in_perpustakaan |
+------------------------+
| anggota                |
| buku                   |
| pinjam                 |
+------------------------+
3 rows in set (0.10 sec)
mysql>
di dalam database perpustakaan sudah ada beberapa table yang telah default dari mysql-nya sendiri. Didalam database tersebut ada table anggota,buku dan pinjam di mana tiap tablenya memiliki fungsi tertentu yang dapat diakses oleh tiap user.
O.    Membuat Database Baru

  •   Membuat database
Untuk membuat sebuah database dengan nama ‘formulir’ kita tidak perlu harus keluar terlebih dahulu dari salah satu database walau kita sebelumnya telah masuk ke dalamnya, untuk membuatnya gunakan syntax berikut

create database Formulir;
mysql> create database Formulir -> ;
Query OK, 1 row affected (0.01 sec)
mysql>
Query OK, 1 row affected (0.01 sec) berarti kita telah berhasil membuat sebuah database yang bernama formulir. Dan untuk menghapusnya, gunakan sintak sebagai berikut :

mysql>drop database formulir;

Pada kondisi di atas, apabila kita lupa meletakkan tanda titik koma (;) di akhir kalimat maka pada baris setelahnya akan keluar tanda (->). Di samping tanda tersebut harus kita beri tanda titik koma (;) agar dapat berjalan dengan baik.

  • Membuat table
Setelah kita memasuki sebuah database, kita dapat mulai membuat tabel – tabel sesuai dengan keperluan kita. Dalam database dikenal primary key, yaitu field yang menjadi acuan data terhadap field-field lainnya dan primary key tidak boleh null.Misalkan nama tabelnya adalah ‘data’, maka sintaknya adalah :
create table data Perhatikan script di bawah ini :

mysql> create table data
-> Nama char(30),
-> Alamat varchar(25),
-> id_formulir int(5));
Query OK, 0 rows affected (0.14 sec)
mysql>

untuk mengecek tabel formulir yang kita buat diatas dengan cara
(mysql>desc data;)
Lihatlah contoh scrip dibawah ini!!!!!
mysql> desc data;
+-------------+-------------+------+-----+---------+-------+
| Field       | Type        | Null | Key | Default | Extra |
+-------------+-------------+------+-----+---------+-------+
| Nama        | char(30)    | YES  |     | NULL    |       |
| Alamat      | varchar(25) | YES  |     | NULL    |       |
| id_formulir | int(5)      | YES  |     | 0       |       |
+-------------+-------------+------+-----+---------+-------+
3 rows in set (0.02 sec)
mysql>

  •   Mengisi table
Setelah tabel terbentuk, kita dapat memulai pekerjaan mengisi database. Syntax yang digunakan adalah :

mysql>insert into data (field1,field2) values (valuefield1,valuefield2);
perhatikan contoh di bawah ini :
mysql> insert into data values ('Fyrman','Bandung','12345');
Query OK, 1 row affected (0.09 sec)
mysql> insert into data values ('Viola','Jakarta','12543');
Query OK, 1 row affected (0.12 sec)
mysql> insert into data values ('Indah','Jogjakarta','12765');
Query OK, 1 row affected (0.07 sec)
mysql> insert into data values ('Alex','Surabaya','12213');
Query OK,  row affected (0.06 sec)
mysql>

Untuk melihat hasilnya yaitu dengan cara (mysql> select * from data;).
mysql> select * from data;
+--------+------------+-------------+
| Nama   | Alamat     | id_formulir |
+--------+------------+-------------+
| Alex   | Surabaya   |       12213 |
| Fyrman | Bandung    |       12345 |
| Viola  | Jakarta    |       12543 |
| Indah  | Jogjakarta |       12765 |
+--------+------------+-------------+
4 rows in set (0.00 sec)
mysql>

Tanda (*) merupakan perintah untuk menampilkan seluruh kolom beserta isinya. Jika kita ingin menampilkan hanya kolom nama saja, maka sintaknya adalah: (mysql>select field from nama_table;). contoh :

select nama from data;
Perhatikan script di bawah ini!!!!!

mysql> select nama from data;
+--------+
| nama   |
+--------+
| Alex   |
| Fyrman |
| Viola  |
| Indah  |
+--------+
4 rows in set (0.00 sec)
mysql>

Untuk mengurutkan data berdasarkan ascending atau descending yaitu dengan cara:
(Select * from data from data order by field asc;), dan sebaliknya.
mysql> select * from data order by nama asc;
+--------+------------+-------------+
| Nama   | Alamat     | id_formulir |
+--------+------------+-------------+
| Alex   | Surabaya   |       12213 |
| Fyrman | Bandung    |       12345 |
| Indah  | Jogjakarta |       12765 |
| Viola  | Jakarta    |       12543 |
+--------+------------+-------------+
4 rows in set (0.04 sec)

mysql> select * from data order by alamat desc;
+--------+------------+-------------+
| Nama   | Alamat     | id_formulir |
+--------+------------+-------------+
| Alex   | Surabaya   |       12213 |
| Indah  | Jogjakarta |       12765 |
| Viola  | Jakarta    |       12543 |
| Fyrman | Bandung    |       12345 |
+--------+------------+-------------+
4 rows in set (0.00 sec)
mysql>
P.     Macam-macam dari perintah DML adalah:
1.      Insert : untuk memasukkan / menambahkan data baru INSERT INTO nama_table (nama_kolom)
values (values);
contoh –> insert into mahasiswa (nim, nama, alamat, jurusan) values (12345,’andhi’,’yogya’,’informatika’);
keterangan:
insert into –> perintah untuk menambah data
mahasiswa –> nama table yang akan ditambahkan datanya
nim, nama, alamat, jurusan –> nama kolom dari table mahasiswa
12345,’andhi’,’yogya’,’informatika’ –> data yang dimasukkan ke dalam table mahasiswa (sesuai dengan urutan kolom yang telah disebutkan sebelumnya)
nb: untuk data yang bertipe karakter harus diapit tanda petik tunggal (‘ ‘)

2.      Select : untuk menyeleksi / memilih data yang akan ditampilkan SELECT * | {nama_kolom} FROM
nama_table [WHERE condition];
contoh –> select nim, nama, jurusan from mahasiswa;
keterangan: perintah di atas menampilkan data nim, nama dan jurusan pada table mahasiswa.
nb: untuk menampilkan semua kolom dapat menggunakan tanda (*) contoh: select * from mahasiswa, sedangkan jika ada syarat/kondisi untuk data yang akan ditampilkan dapat menggunakan klausa where contoh: select nim, nama from mahasiswa where nama=’andhi’

3.      Update : untuk membperbaharui data yang sudah ada UPDATE nama_table SET nama_kolom = value [WHERE condition];
contoh –> update mahasiswa set jurusan =’kedokteran’ where nama=’andhi’;
keterangan: perintah di atas akan mengubah data mahasiswa yang bernama andhi dengan mengganti data pada kolom jurusan, yang sebelumnya informatika menjadi kedokteran.
Nb: kita dapat mengubah lebih dari satu kolom dalam satu perintah update contoh: update mahasiswa set nim=45678, jurusan=’kedokteran’ where nama=’andhi’;
Perhatian : Jika kita tidak menggunakan klausa where maka semua baris pada kolom yang akan di update akan berubah.

4.      Delete : untuk menghapus baris data DELETE [FROM] nama_table [ WHERE condition];
contoh –> delete mahasiswa where nama=’andhi’;
keterangan: perintah di atas menghapus baris data pada tabel mahasiswa yang bernaa andhi
Perhatian : Jika tidak menggunakan klausa where maka semua baris data pada tabel tersebut akan dihapus.
Q.      Mengatur MySQL bisa menggunakan jaringan (diakses dengan visual basic dari komputer klien)
Database MySQL diperuntuhkkan untuk PHP, dengan kata lain, pengaksesan melalui jaringan adalah fitur utama dari database ini. Pengaksesan melalui jaringan pada prinsipnya MySQL dijalankan di server (Server Side) sehingga hak akses yang digunakan sebenarnya lokal. Hal yang berbeda kalau kita ingin mengakses database tersebut secara Client Side.
Misalnya ingin mengakses database dari sebuah PC dengan menggunakan Visual Basic. Kita harus mempersiapkan MySQL yang bisa menggunakan jaringan.
Untuk kegiatan ini diperlukan requirement sebagai berikut:
1. Antar muka MySQL seperti PHPMyAdmin
2. Windows XP di Server (dan akses ke control panelnya)
3. Sedangkan Langkah-langkah yang harus kita lakukan adalah:
4. Atur  firewall komputer server
5. Menambahkan user MySQL untuk komputer klien

Tidak ada komentar:

Posting Komentar

KARYA ILMIAH

PENYALAHGUNAAN INTERNET DI KALANGAN REMAJA KATA PENGANTAR Segala puji syukur kami panjatkan kehadirat Tuhan Yang Maha Esa, yang sen...