Presentasi sedang didownload. Silahkan tunggu

Presentasi sedang didownload. Silahkan tunggu

Materi pertemuan. Bahasa Query Bahasa yang digunakan user untuk melakukan request informasi dari basis data Kategori Bahasa : Prosedural Non-prosedural.

Presentasi serupa


Presentasi berjudul: "Materi pertemuan. Bahasa Query Bahasa yang digunakan user untuk melakukan request informasi dari basis data Kategori Bahasa : Prosedural Non-prosedural."— Transcript presentasi:

1 Materi pertemuan

2 Bahasa Query Bahasa yang digunakan user untuk melakukan request informasi dari basis data Kategori Bahasa : Prosedural Non-prosedural Bahasa “Murni” (“Pure” languages) : Aljabar Relasional Tuple Relational Calculus Domain Relational Calculus Pure languages membentuk dasar bahasa query yang digunakan user.

3 Bahasa query memungkinkan manipulasi dan pemanggilan data dari suatu basisdata. Terdapat 2 macam bentuk bahasa query” Aljabar Relasional Aljabar relasional adalah sebuah bahasa query prosedural yang terdiri dari sekumpulan operasi dimana masukkannya adalah satu atau dua relasi dan keluarannya adalah sebuah relasi baru sebagai hasil dari operasi tersebut Lebih bersifat operasional, sangat berguna untuk merepresentasikan eksekusi perencanaan Kalkulus Relasional Memungkinkan user menggambarkan apa yang mereka inginkan, tidak pada pada bagaimana cara melakukan komputasi terhadap apa yang mereka inginkan tersebut. (tidak bersifat operasional, tapi bersifat deklaratif). Memahami aljabar dan kalkulus relasional adalah kunci memahami SQL.

4 Aljabar Relasional Merupakan bahasa prosedural Operator dasar : select project union set difference Cartesian product rename Operator yang melibatkan dua atau lebih relasi sebagai input akan menghasilkan satu relasi baru sebagai output.

5 Operasi Dalam Aljabar Relasional Operasi-operasi dasar dalam aljabar relasional adalah : Select : memilih sub himpunan baros dari suatu relasi Project : Menghapus kolom yang tidak dikehendaki dari relasi Union : Mendapatkan tupel yang terdapat dalam relasi satu dan relasi dua. set difference : mendapatkan tupel yang terdapat dalam relasi satu tapi tidak terdapat dalam relasi dua. Operasi tambahan : Intersection Join Division renaming

6 Operasi Select (Contoh)

7 Operasi-operasi select, project dan rename disebut operasi unary, karena operasi-operasi tersebut hanya memerlukan satu relasi. Tiga operasi lainnya memerlukan sepasang relasi, disebut operasi binary.

8 Definisi Operasi Select Notasi : σ p (r) p disebut sebgai predikat selection Definisi selection : σ p (r) = {t | t ε r and p(t)} Di mana p adalah sebuah formula dalam kalkulus proposisi yang terdiri atas term yang dihubungkan dengan Setiap term adalah satu dari : op or di mana op adalah salah satu dari : =, ≠, >, ≥. <. ≤ Contoh selection: σ branch-name=“Perryridge”(account)

9 Operasi SELECT Operasi select menyeleksi tuple-tuple yang memenuhi predikat yang diberikan. Digunakan symbol sigma (σ) untuk menunjukkan operasi select. Predikat muncul sebagai subcript dari σ. Argumen relasi diberikan dalam kurung yang mengikuti σ. Jadi untuk menyeleksi tuple-tuple dari relasi S2 dimana rating-nya lebih besar dari 8, ditulis : σ rating>8 (S2) Maka tabel yang dihasilkan:

10 Jika relasi S2 adalah : Contoh-contoh query lain dengan operasi select adalah : σage = “35.0”(S2) Yang artinya : menyeleksi tuple-tuple dari relasi S2 dimana age-nya adalah “35.0”

11 Definisi Operasi Project Notasi : Π A1, A2, …, Ak (r) di mana A 1, A 2 adalah nama atribut, dan r adalah nama relasi. Hasil operasi project didefinisikan sebagai relasi dengan kolom sebanyak k yang diperoleh dengan menghapus kolom yang tidak termasuk dalam kriteria. Duplicate rows dihilangkan dari relasi hasil, karena relasi adalah sebuah himpunan. Contoh : apabila kita ingin memperoleh informasi dari relasi account, tetapi tanpa atribut branch-name : Π account-number, balance (account)

12 Operasi Project Seandainya diinginkan semua daftar sname dan rating, dengan rating >8. Dengan operasi project dapat dihasilkan relasi ini. Operasi project disimbolkan dengan symbol phi (π). Nama-nama atribut yang diinginkan tampil ditulis sebagai subcript π Contoh : πsname,rating(σ rating>8 (S2)), adalah operasi untuk menampilkan seluruh sname & rating dengan rating > 8 Hasil operasi tersebut adalah :

13 Contoh Operasi Projection

14 Union, Intersection, Set-Difference Semua Operasi ini membutuhkan dua relasi, syarat yang harus di penuhi adalah: Mempunyai jumlah field yang sama Field yang berkorespondensi memiliki tipe yang sama. Untuk dua tabel relasi S1 dan S2 berikut:

15 Contoh Operasi Union

16 Definisi Operasi Union Notasi: r U s Definisi operasi union : r U s = {t | t ε r or t ε s} Kriteria valid r U s : 1. r, s harus mempunyai arity sama (jumlah atributnya sama) 2. Domain atribut harus kompatibel (misal : kolom kedua relasi r mempunyai tipe data yang sama dengan kolom kedua relasi s) Contoh : untuk mencari semua customer yang mempunyai account atau pinjaman : Π customer-name (depositor) U Π customer-name (borrower)

17 Contoh Operasi Set Difference

18 Definisi Operasi Set Difference Notasi : r – s Definisi : r – s = {t | t ε r and t ∉ s} Operasi set difference harus dilakukan pada relasi yang kompatibel : r dan s harus mempunyai arity sama Domain atribut r dan s harus kompatibel

19 Berikut ini adalah contoh dari ketiga operasi diatas: Union : S1 U S2 Intersection: S1 n S2 Set-Difference:

20 Cross-Product Cross Product biasa dikenal dengan Operasi Cartesian- product. Operasi Cartesian-product disimbolkan dengan “x”. Dengan operasi ini dapat dihasilkan informasi yang merupakan kombinasi dari dua relasi. Secara garis besar, jika dipunyai relasi r1(R1) dan r2(R2), maka r1 x r2 adalah relasi yang skemanya merupakan gabungan dari R1 ( atribut-atribut relasi r1) dan R2 (atribut-atribut r2). Relasi R mengandung semua tuple t dimana terdapat sebuah tuple t1 dalam r1 dan t2 dalam r2 sedemikian sehingga t[R1] = t1[R1] dan t[R2]=t2[R2].

21 Contoh : S1 x R1

22 Contoh Operasi Cartesian-Product

23 Definisi Operasi Cartesian-Product Notasi : r x s Definisi : r x s = {t q | t ε r and q ε s} Asumsi atribut r(R) dan s(S) disjoint. (Yaitu R ∩ S = ∅ ). Jika atribut r(R) dan s(S) tidak disjoint, maka harus dilakukan renaming.

24 Komposisi Beberapa Operasi Contoh: σ A=C (r x s)

25 Operasi Rename Memungkinkan untuk memberi nama dan mengacu hasil dari operasi ekspresi aljabar relasional. Memungkinkan untuk mengacu sebuah relasi dengan lebih dari satu nama. Contoh : ρ x (E) mengembalikan ekspresi E dengan nama Jika ekspresi aljabar relasional E mempunyai arity n, maka ρ x (A 1, A 2, …, A n ) (E) mengembalikan hasil ekspresi E dengan nama X, dan atributnya direname menjadi A 1, A 2, …., A n.

26 Contoh Skema Perbankan branch (branch-name, branch-city, assets) customer (customer-name, customer-street, customer- only) account (account-number, branch-name, balance) loan (loan-number, branch-name, amount) depositor (customer-name, account-number) borrower (customer-name, loan-number)

27 Contoh Query Cari semua loan yang nilainya lebih dari $1200 σ amount > 1200 (loan) Cari nomor loan untuk semua loan yang nilainya lebih dari $1200 Π loan-number (σ amount > 1200 (loan))

28 Contoh Query Cari nama semua customer yang mempunyai loan, account, atau keduanya. Π customer-name (borrower) U Π customer-name (depositor) Cari nama semua customer yang mempunyai loan dan account. Π customer-name (borrower) ∩ Π customer-name (depositor)

29 Contoh Query Cari nama semua customer yang mempunyai loan di branch Perryridge. Π customer-name (σ branch-name=“Perryridge” (σ borrower.loan-number = loan.loan-number (borrower x loan))) Cari nama semua customer yang mempunyai loan di branch Perryridge, tetapi tidak mempunyai account di branch manapun. Π customer-name (σ branch-name = “Perryridge” (σ borrower.loan-number = loan.loan-number (borrower x loan))) – Π customer-name (depositor)

30 Contoh Query Cari nama semua customer yang mempunyai loan di branch Perryridge. Query 1 Πcustomer-name(σ branch-name = “Perryridge” ( σ borrower.loan-number = loan.loan-number (borrower x loan))) Query 2 Πcustomer-name(σ loan.loan-number = borrower.loan- number ((σ branch-name = “Perryridge” (loan)) x borrower))

31 Contoh Query Cari nilai balance account yang paling besar Rename relasi account sebagai d Query : Π balance (account) - Π account.balance (σ account.balance < d.balance (account x ρd (account)))

32 Latihan : Diketahui skema basis data sbb: employee (person-name, street, city) works (person-name, company-name, salary) company (company-name, city) manages (person-name, manager-name) a.Cari nama employee yang bekerja pada First Bank Corporation. b.Cari nama dan kota tempat tinggal semua employee yang bekerja di First Bank Corporation. c. Cari nama, alamat dan kota tempat tinggal semua employee yang bekerja di First Bank Corporation dan berpenghasilan lebih dari $10,000. d. Cari nama semua employee yang tinggal di kota yang sama dengan perusahaan dimana mereka bekerja. e. Cari nama semua employee yang tinggal di kota dan jalan yang sama dengan manager mereka. f. Cari nama semua employee yang tidak bekerja di First Bank Corporation. g. Cari semua nama employee yang penghasilannya lebih dari employee di Small Bank Corporation. h. Asumsikan perusahaan berlokasi di beberapa kota. Cari semua perusahaan yang berlokasi di setiap kota dimana Small Bank Corporation berada.


Download ppt "Materi pertemuan. Bahasa Query Bahasa yang digunakan user untuk melakukan request informasi dari basis data Kategori Bahasa : Prosedural Non-prosedural."

Presentasi serupa


Iklan oleh Google