BAHASA QUERY KOMERSIAL

dokumen-dokumen yang mirip
BAHASA QUERY KOMPLEKS

BAHASA QUERY KOMERSIAL

BAHASA QUERY KOMERSIAL

BAHASA QUERY KOMERSIAL

Pertemuan 11. Bahasa Query Terapan Lanjutan

BAHASA QUERY KOMERSIAL

Pertemuan 10. Bahasa Query Terapan

STRUCTURE QUERY LANGUAGE ( S Q L ) Jenis SQL 1. Interactive langsung dapat dioperasikan 2. Embedded disisipkan ke dalam sebuah program

STRUCTURE QUERY LANGUAGE ( S Q L )

STRUCTURE QUERY LANGUAGE ( S Q L ) Pengelompokan Statement SQL 1. Data Definition Language ( DDL )

Statement DDL Create database drop database Create table drop table alter table

Macam - Macam Perintah Pada SQL

SQL OVERVIEW. Widio Riyanto. A. Definisi SQL

SEKOLAH TINGGI TEKNOLOGI INDONESIA TANJUNG PINANG

PENGANTAR TEKNOLOGI SISTEM INFORMASI MANAGEMENT 2

MODUL V DATA MANIPULATION LANGUAGE (DML) 1


S Q L STRUCTURED QUERY LANGUAGE DEFINITION MANIPULATION C O N T R O L D M L SELECT INSERT UPDATE DELETE

Mahasiswa mengetahui & memahami mengenai DML, DCL di SQL. (Isi_Field_1, Isi_Field_2,, Isi_Field_N) ;

STRUCTURE QUERY LANGUAGE

Database Systems: Lab. Actvity 1: Database Design. Merancang Database. Merancang Database. Tipe Tabel MySQL.

STRUCTURE QUERY LANGUAGE (SQL)

LAPORAN TUGAS BASIS DATA I

Praktikum Basis Data. By. Rita Wiryasaputra, ST., M. Cs.

STRUCTURED QUERY LANGUAGE (SQL) (Implementasi menggunakan MySQL)

Sistem Basis Data 1. Pertemuan 5 dan 6 Aljabar Relasional dan SQL Rogayah, ST.,MMSI Untuk 3DB01 dan 3DB04

Data Manipulation Language (DML) & Data Control Language (DCL) pada Database

KOMPONEN DASAR DARI SISTEM DATABASE

Pengenalan Structured Query Language

Apakah SQL? Membuat basis data dan struktur tabel Input, update, dan delete data dari tabel Membuat query sederhana dan kompleks SQL

STRUCTURE QUERY LANGUAGE DDL & DML

FAKULTAS TEKNIK UNIVERSITAS NEGERI YOGYAKARTA LAB SHEET PEMROGRAMAN WEB Semester: 2 MYSQL 200 menit No.: Job: 12 Tgl: Hal.

Komponen-Komponen SQL a. Data Definition Language (DDL) : Digunakan untuk mendefinisikan data dengan menggunakan perintah : create, drop, alter.

Sejarah(1) Sejarah(2) STRUCTURE QUERY LANGUANGE (1) Definisi SQL

MODEL DATA RELASIONAL

Apa yang akan dibahas? Pengertian SQL Penggolongan Statement SQL Aturan Gramatika SQL Struktur Dasar SQL Query Satu (1) Tabel

Jobsheet SQL Dasar : Hari Zulianto, ST [Year]

Sistem Basis Data Danny Kriestanto, S.Kom., M.Eng

Perangkat Lunak Pengembangan Web

Pengertian Query. Query adalah perintah-perintah untuk mengakses data pada sistem basis data

Database Management System. Program yang memungkinkan item-item dalam suatu database disusun, diolah dan diperbaharui

SISTEM BASIS DATA 1. WAHYU PRATAMA, S.Kom., MMSI.

Untuk menjalankan Mysql secara konpensional jalankan Mysql.exe pada direktori Mysql\Bin. Akan tampak tampilan sebagai berikut:

Pertemuan 12 Pengenalan Structured Query Language

BAB III STRUCTURED QUERY LANGUAGE (SQL)

Konsep Sistem Informasi B. BAB 2 - SQL Overview

Untuk mengakses MySQL dengan mode text dari Console (Command Prompt = Microsoft Windows), dapat dilakukan dengan cara : 1.

SQL (STRUCTURED QUERY LANGUAGE)

Riyanto

MODUL 1 Pengenalan MySQL, DDL, DML

SISTEM BASIS DATA 1. WAHYU PRATAMA, S.Kom., MMSI.

Praktikum Basis Data 14 Structure Query Language 2

RENCANA PEMBELAJARAN

Model Relasional Basis Data

Data Manipulation Language (DML)

PERANCANGAN BASIS DATA

VIEW : Tabel Virtual VIEW 5/29/2017

Pemrograman Web Lanjut 2017

DATABASE - MySQL. Muhammad Zen S. Hadi, ST. MSc.

LAPORAN PRAKTIKUM MODUL 1 PENGENALAN MYSQL

MODUL PEMPROGRAMAN SQL TINGKAT DASAR 1 STANDAR KOMPETENSI: MENERAPKAN BAHASA PEMPROGRAMAN SQL TINGKAT DASAR SMK NEGERI 1 MAJALENGKA

SQL (Structure Query Language) Gentisya Tri Mardiani, S.Kom

SUBQUERY VIEW JOIN PRAKTIKUM BERKAS DAN BASIS DATA 2010/2011. Rizki Arif Firdaus

MENGENAL SYNTAX DML PADA SQL

Hendra Setiawan ( )

Praktikum 2 Mata Kuliah : Sistem Pengolahan Basis Data Dosen : Nandang Hermanto

STMIK SUMEDANG DATA DEFINITION LANGUAGE (DDL) TUGAS PRAKTEK PEMROGRAMAN BASIS DATA. Nama : NIKKI BAGUS N A NIM : A Kelas : TI 4A

SISTEM BASIS DATA. Oleh : Devie Rosa Anamisa

LAPORAN PRAKTIKUM BASIS DATA LANJUT I

Basis Data Spasial Modul 2

PEMROGRAMAN WEB 2 DATABASE,MYSQL. Rio andriyat krisdiawan, m.kom

Pertemuan III Oleh: Ilham Rais Arvianto, M.Pd

Untuk mencoba contoh-contoh perintah join, silahkan eksekusi query create+insert dibawah ini:

Rencana Pelaksanaan Pembelajaran

Pengenalan Database Management System MySQL. Pokok Bahasan: Pengenalan DataBase Pembangunan database berbasis Client-Server Dasar-Dasar MySQL

DAFTAR ISI. DAFTAR ISI... 1 PRAKATA Pengenalan dan Lingkungan Kerja MySQL Tujuan... 4 Dasar Teori... 4 Praktik... 5

Praktikum Basis Data 2017 TE UM

Untuk menampilkan data-data yang telah tersimpan dalam database diperlukan perintah SELECT, yang dapat dirumuskan sebagai berikut:

By : Hanung Nindito Prasetyo. Program Studi Teknik Komputer Jurusan Teknologi Informasi Politeknik Telkom 2012

S Q L. Sejarah SQL. Penulisan Perintah SQL. SQL (Structure Query Language)

MODUL II SQL A. TUJUAN

Basis Data. Bagian IV SQL (3) Fak. Teknik Jurusan Teknik Informatika Universitas Pasundan

RENCANA PEMBELAJARAN SEMESTER (RPS) DAN RENCANA PELAKSANAAN PEMBELAJARAN (RPP)

MySQL. Setelah Anda melakukan tahapan-tahapan di atas Anda akan dapatkan screen seperti ini

Konsep Dasar. Relatsional dan RDBMS User dan Schema Database Membuat Tabel dan Mendefinisikan Constraint Input Data ke dalam Tabel

PERTEMUAN 10. SQL : Data Manipulation (Chap. 6 Conoly)

PRAKTIKUM 5 SISTEM BASIS DATA JOIN

SISTEM BASIS DATA SQL

Praktikum Basis Data (Database Server MySQL) Bekerja Dengan Tabel

Modul 3 : Query Penggabungan Tabel

Pemrograman Basis Data Berbasis Web

P - 7 Pembahasan UTS PSIK V

MySQL AL AZHAR COMPUTER CLUB

MODUL I PENGENALAN MYSQL

RANGKUMAN PHP dan MYSQL

Pertemuan 3 dan 4 : MODEL DATA RELASIONAL

Syntax Syntax SQL. Untuk lebih jelasnya dapat dilihat sebagai berikut : 1. DDL (Definition Data Language) a. CREATE

15-Jan DATABASE - MySQL. Database. Constraints. Tujuan: Memahami perintah-perintah dasar DDL dan DML

PENGANTAR PRAKTIKUM BERKAS DAN BASIS DATA 2010/2011. Rizki Arif Firdaus

LAPORAN PRAKTIKUM BASIS DATA

Transkripsi:

Pertemuan 10 BAHASA QUERY KOMERSIAL BAHASA QUERY KOMERSIAL STRUKTUR QUERY LANGUAGE (SQL) SQL dipublikasikan oleh E.F. CODD (1970) mengenai model relational. Kemudian pada tahun 1974, D. Chamberlin dan R.F. Boyce mengembangkan bahasa query untuk memanipulasi dan mengekstraksi data dari basisdata relational. Sasaran SQL a. Menciptakan basis data dan struktur relasi b. Melakukan menajemen data tingkat dasaar c. Membentuk query sederhana dan kompleks d. Melakukan tugas-tugas dengan seminimal mungkin memakai struktur dan sintaks perintah relatif mudah dipelajari e. Harus portabel 1

Jenis SQL : 1. Interactive SQL 2. Static SQL 3. Dynamic SQL Subdivisi SQL 1. DDL (Data Definition Language) Query-query ini digunakan untuk mendefinisikan struktur atau skema basis data 2. DML (Data Manipulation Language) Query-query ini digunakan untuk manajemen data dalam basis data 3. DCL ( Data Control Language) Query-query ini berhubungan dengan pengaturan hak akses dan wewenang. PENGELOMPOKAN STATEMEN SQL 1. Data Definition Language (DDL) CREATE DATABASE DROP DATABASE CREATE TABEL DROP TABEL CREATE INDEX DROP INDEX CREATE VIEW DROP VIEW ALTER TABLE 2. Data Manipulation Language INSERT, SELECT, UPDATE, DELETE 2

3. Data Access GRANT, REVOKE 4. Data Integrity RECOVER TABLE 5. Auxiliary SELECT INTO OUTFILE, LOAD, RENAME TABLE KASUS DATA DEFINITION LANGUAGE (DDL) A. CREATE 1. Pembuatan Database Nama Database adalah yang dapat mewakili suatu kejadian dapat berupa nama organisasi atau perusahaan. Sintaks : CREATE DATABASE nama_database Buat database dengan nama PT.ABC CREATE DATABASE PT.ABC 2. Pembuatan Tabel Sintaks : CREATE TABLE nama_table ( nama_kolom1 tipe_data_kolom1, nama_kolom2,tipe_data_kolom2,.) Buat struktur tabel dengan nama tabel MHS dengan data NIM char(8), NAMA char(25), ALAMAT char(30) CREATE TABLE MHS (NIM char(8) not null, NAMA char(25) notnull, ALAMAT char(30) notnull) 3

3. Pembuatan Index Sintaks : CREATE [UNIQUE] INDEX nama_index ON nama_table (nama_kolom) ; Buat index data mahasiswa berdasarkan NIM dengan nama MHSIDX Dimana NIM tidak boleh sama CREATE UNIQUE INDEX MHSIDX ON MHS(NIM) 4. Pembuatan View Sintaks : CREATE VIEW nama_view [ (nama_kolom1,.) ] AS SELECT statement [WITH CHECK OPTION] ; Buat view dengan nama MHSVIEW yang berisi semua data mahasiswa CREATE VIEW MHSVIEW AS SELECT * FROM MHS B. DROP (MENGHAPUS) 1. Menghapus Database Sintaks : DROP DATABASE nama_db ; 2. Menghapus Tabel Sintaks : DROP TABLE nama_table ; 3. Menghapus Index Sintaks : DROP INDEX nama_index ; 4. Menhapus View Sintaks : DROP VIEW nama_view ; DROP DATABASE Mahasiswa; DROP TABLE MHS; DROP INDEX MHSIDX; DROP VIEW MHSVIEW; 4

C. ALTER TABLE (MERUBAH STRUKTUR TABEL) Sintaks : ALTER TABLE nama_tabel ADD nama_kolom jenis_kolom [FIRST AFTER nama_kolom] CHANGE [COLUMN] oldnama newnama MODIFY nama_kolom jenis kolom, DROP nama_kolom RENAME newnama_tabel 1. Tambahkan kolom JKEL dengan panjang 1 char pada tabel MHS ALTER TABLE MHS ADD JKEL char(1); 2. Ubah panjang kolom MTKULIAH menjadi 30 char ALTER TABLE MKUL MODIFY COLUMN MTKULIAH char(30); 3. Hapus kolom JKEL dari data table MHS ALTER TABLE MHS DROP JKEL; DATA MANIPULATION LANGUAGE (DML) 1. INSERT Sintaks : INSERT INTO Nama_tabel [(nama_kolom1, )] Masukan data matakuliah Berkas Akses dengan kode KK222 besarnya 2 INSERT INTO MKUL VALUES( KK222, Berkas Akses, 2); dan 2. UPDATE Sintaks : UPDATE nama_tabel SET nama_kolom = value_1 WHERE kondisi ; Ubah alamat menjadi Depok untuk mahasiswa yang memiliki NPM 50096487 UPDATE MHS SET ALAMAT= Depok WHERE NPM= 50096487 ; 5

3. DELETE Sintaks : DELETE FROM nama_table WHERE kondisi Hapus data nilai matakuliah bagi mahasiswa yang mempunyai NPM 10296832 DELETE FROM NILAI WHERE NPM= 10296832 AND KDMK= Tabel dibawah ini untuk mengerjakan Select (tampilan) dari SQL Tabel Mahasiswa Tabel Nilai NIM NAMA_MHS ALAMAT_MHS 10296832 10296126 31296500 41296525 50096487 21196353 10296001 21198002 Nurhayati Astuti Budi Prananigrum Pipit Quraish Fintri Julizar Jakarta Jakarta Depok Bogor Bekasi Bogor Depok Jakarta Tabel MataKuliah KD_MK NAMA_MK SK S Sistem Basis Data Sistem Informasi Manajemen Pancasila 2 3 2 NIM NO_MK MID FINAL 10296832 10296126 31296500 41296525 21196353 50095487 60 70 55 90 80 90 40 80 0 6

4. SELECT Sintaks : SELECT [DISTINCT ALL] nama_kolom FROM nama_tabel [ WHERE condition ] [ GROUP BY column_list ] [HAVING condition ] [ ORDER BY column_list [ASC DESC]] a. Tampilkan semua data mahasiswa SELECT NIM,NAMA,ALAMAT FROM MAHASISWA; Atau SELECT * FROM MAHASISWA; Maka hasilnya adalah : NIM NAMA_MHS ALAMAT_MHS 10296832 10296126 31296500 41296525 Nurhayati Astuti Budi Prananingrum Jakarta Jakarta Depok Bogor 7

b. Tampilkan Mata Kuliah yang SKSnya 2 Select NAMA_MK from matakuliah Where sks = 2 Maka Hasilnya : NAMA_MK Sistem Basis Data Pancasila c. Tampilkan semua data nilai dimana nilai MID lebih besar sama dengan 60 atau nilai finalnya lebih besar. maka penulisannya : SELECT * FROM NILAI WHERE MID >= 60 OR FINAL > Hasilnya : NIM NO. MK MID FINAL 10296832 10296126 41296525 21196353 60 70 90 90 80 8

JOIN 1. JOIN atau INNER JOIN Menggabungkan dua tabel dimana diantara dua tabel datanya bersesuaian. 2. LEFT JOIN atau LEFT OUTER JOIN Menggabungkan dua tabel dimana diantara dua tabel datanya bersesuaian dan juga semua record pada tabel sebelah kiri. 3. RIGHT JOIN atau RIGHT OUTER JOIN Menggabungkan dua tabel dimana diantara dua tabel datanya bersesuaian dan juga semua record pada tabel sebelah kanan. SELECT Nilai.NIM, NAMA_MHS, KD_MK, MID FROM Nilai INNER JOIN Mahasiswa ON Nilai.NIM = Mahasiswa.NIM Hasil : NIM NAMA_MHS KD_MK MID 10296832 10296126 31296500 41296525 21196353 50095487 Nurhayati Astuti Budi Prananigrum Quraish Pipit 60 70 55 90 80 9

SELECT Mahasiswa.NIM, NAMA_MHS, KD_MK, MID FROM Mahasiswa LEFT OUTER JOIN Nilai ON Nilai.NIM = Mahasiswa.NIM Hasil : NIM NAMA_MHS KD_MK MID 10296832 10296126 31296500 41296525 21196353 50095487 10296001 21198002 Nurhayati Astuti Budi Prananigrum Quraish Pipit Fintri Julizar - - 60 70 55 90 80 - - SELECT Mahasiswa.NIM, NAMA_MHS, KD_MK, MID FROM Nilai RIGHT OUTER JOIN Mahasiswa ON Nilai.NIM = Mahasiswa.NIM Hasil : NIM NAMA_MHS KD_MK MID 10296832 10296126 31296500 41296525 21196353 50095487 10296001 21198002 Nurhayati Astuti Budi Prananigrum Quraish Pipit Fintri Julizar - - 60 70 55 90 80 - - 10

DATA ACCESS 1. GRANT Sintaks : GRANT hak_akses ON nama_db TO nama_pemakai [IDENTIFIED BY] [PASSWORD] Password [WITH GRANT OPTION] ; GRANT hak_akses ON [nama_db.]nama_tabel TO nama_pemakai [IDENTIFIED BY] [PASSWORD] Password [WITH GRANT OPTION]; Berikan hak akses kepada Adi untuk menampikan nilai final test pada tabel Nilai. GRANT SELECT (FINAL) ON NILAI TO ADI 2. REVOKE Sintaks : REVOKE hak_akses ON nama_db FROM nama_pemakai ; REVOKE hak_akses ON nama_tabel FROM nama_pemakai ; Tarik kembali dari Adi hak akses untuk menampilkan nilai final test REVOKE SELECT (FINAL) ON NILAI FROM ADI 11

DATA INTEGRITY RECOVER TABLE Sintaks : RECOVER TABLE nama_tabel Kembalikan keadaan data mahasiswa seperti pada saat sebelum terjadi kerusakan RECOVER TABLE MAHASISWA ; AUXILIARY 1. SELECT INTO OUTFILE filename Sintaks ini digunakan untuk mengekspor data dari tabel ke file lain. Sintaks : SELECT INTO OUTFILE Nama File [FIELDS COLUMNS] [TERMINATED BY 'string'] [[OPTIONALLY] ENCLOSED BY 'char'] [ESCAPED BY 'char'] ] Ubah semua data mahasiswa ke bentuk ASCII dan disimpan ke file teks di directory/home/adi dengan pemisah antar kolom SELECT * FROM MAHASISWA INTO OUTFILE /home/adi/teks FIELDS TERMINATED BY ; 12

2. LOAD Sintaks query ini digunakan untuk mengimpor data dari file lain ke tabel. Sintaks : LOAD DATA INFILE nama_path INTO TABLE nama_tabel [ nama_kolom] ; [FIELDS COLUMNS] [TERMINATED BY 'string'] [[OPTIONALLY] ENCLOSED BY 'char'] [ESCAPED BY 'char'] ] Memasukkan data-data dari file teks yang berada pada direktori /home/adi ke dalam tabel MHS_2. Dimana pemisah antara kolom dalam file teks adalah tab (\t) : LOAD FROM /home/adi/teks INTO MHS_2 FILELDS TERMINATED BY \t ; 3. RENAME TABLE Sintaks : RENAME TABLE OldnamaTabel TO NewNamaTabel RENAME TABLE MAHASISWA TO MHS 13

MENGGUNAKAN FUNGSI AGGREGATE : 1. COUNT digunakan untuk menghitung jumlah. Menghitung jumlah record mahasiswa dari tabel MAHASISWA SELECT COUNT(*) FROM MAHASISWA 2. SUM digunakan untuk menghitung total dari kolom yang mempunyai tipe data numerik. SELECT SUM(SKS) AS TOTAL SKS FROM MATAKULIAH 3. AVG digunakan untuk menghitung rata-rata dari data-data dalam sebuah kolom. SELECT AVG(FINAL) AS FINAL FROM Nilai 4. MIN digunakan untuk menghitung nilai minimal dalam sebuah kolom. SELECT MIN(FINAL) FROM Nilai 5. MAX diguankan untuk menghitung nilai maksismum dalam sebuah kolom SELECT MAX(MID) FROM Nilai 14

SUBQUERY Adalah subselect yang dapat digunakan di klausa WHERE dan HAVING dipernyataan select luar untuk menghasilkan tabel akhir. Aturan-aturan untuk membuat subquery, yaitu : 1. Klausa Order By tidak boleh digunakan di subquery, Order By hanya dapat digunakan di pernyataan Select luar. 2. Klausa subquery Select harus berisi satu nama kolom tunggal atau ekspresi kecuali untuk subquery-subquery menggunakan kata kunci EXIST 3. Secara default nama kolom di subquery mengacu ke nama tabel di klausa FROm dari subquery tersebut. 4. Saat subquery adalah salah satu dua operan dilibatkan di pembandingan, subquery harus muncul disisi kanan pembandingan Penggunanaan ANY dan ALL Jika subquery diawali kata kunci ALL, syarat hanya akan bernilai TRUE jika dipenuhi semua nilai yang dihasilkan subquery itu. Jika subquery diawali kata kunci ANY, syaratnya akan bernilai TRUE jika dipenuhi sedikitnya satu nilai yang dihasilkan subquery tersebut. 15

Penggunanaan EXIST DAN NOT EXIST EXIST akan mengirim nilai TRUE jika dan hanya jika terdapat sedikitnya satu baris di tabel hasil yang dikirim oleh subquery dan EXIST mengirim nilai FALSE jika subquery mengirim tabel kosong. Untuk NOT EXIST kebalikan dari EXIST. (Masing-masing dosen membuat contoh untuk subquery) CONTOH SUBQUERY : 1. Coba ambil nilai mid dan final dari mahasiswa yang bernama Astuti. SELECT MID, FINAL FROM NILAI WHERE NIM=( SELECT NIM FROM MAHASISWA WHERE NAMA_MHS= Astuti ) 2. Ambil nilai kode matakuliah, mid dan final dari mahasiswa yang tinggal di jakarta. SELECT KD_MK, MID, FINAL FROM NILAI WHERE NIM IN(SELECT NIM FROM MAHASISWA WHERE ALAMAT_MHS = Jakarta ) 16

3. Ambil nama-nama mahasiswa yang mengikuti ujian. SELECT NAMA FROM MAHASISWA WHERE EXISTS (SELECT NIM FROM NILAI WHERE NILAI.NIM= MAHASISWA.NIM) 4. Ambil nama-nama mahasiswa yang tidak mengikuti ujian. SELECT NAMA FROM MAHASISWA WHERE NOT EXISTS (SELECT NIM FROM NILAI WHERE NILAI.NIM= MAHASISWA.NIM) Aplikasi yang digunakan sebagai contoh adalah phptriad-mysql front Dari Address ketik : http://localhost/phpmyadmin Tampilan password ketik root dan untuk password ketik password 17