Membuat Objek Skema Lainnya
Selain tabel, objek skema penting lainnya adalah view, sequence, indexes dan sinonim. View adalah tabel logis atau virtual. Sinonim hanyalah nama alias untuk objek database. Sinonim juga menyederhanakan penulisan kueri dan menyediakan elemen keamanan sistem dengan menyamarkan nama sebenarnya dari objek database. Urutan adalah objek database khusus yang mendukung pembuatan otomatis nilai integer, dan sering digunakan untuk menghasilkan nilai kunci utama untuk tabel. Indeks dibuat pada kolom tabel untuk memfasilitasi pengambilan informasi dari tabel dengan cepat.
Tampilan
Tampilan database adalah tabel logis atau virtual berdasarkan kueri. Tampilan dikueri seperti tabel. Ini berarti bahwa dari perspektif Anda sebagai pengembang atau dari perspektif pengguna sistem database, tampilan tampak seperti tabel. Definisi tampilan sebagai objek disimpan dalam kamus data database; Namun, tampilan tidak menyimpan data itu sendiri. Database juga menyimpan rencana eksekusi untuk membuat tampilan - ini berarti bahwa data dapat diambil dengan cepat melalui penggunaan tampilan meskipun data aktual yang disajikan oleh kueri SELECT dari tampilan tidak disimpan sebagai bagian dari sebuah view. Sebaliknya, data "dikumpulkan bersama" setiap kali sebuah view di-query dari tabel database yang view-nya ditentukan-ini disebut tabel-tabel dasar.
Sintaks umum diberikan di bawah ini.
CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW [ViewName]
[(Column Alias Name...)]
AS [Query]
[WITH [CHECK OPTION] [READ ONLY] [CONSTRAINT]];
Dari sintaks,
Opsi FORCE memungkinkan tampilan dibuat meskipun tabel dasar yang referensi tampilan belum ada. Opsi ini digunakan untuk membuat tampilan sebelum pembuatan sebenarnya dari tabel dasar dan data yang menyertainya.
Opsi NOFORCE adalah kebalikan dari FORCE dan memungkinkan pengguna sistem untuk membuat tampilan jika mereka memiliki hak istimewa yang diperlukan untuk membuat tampilan, dan jika tabel tempat tampilan dibuat sudah ada. Ini adalah opsi default.
Opsi DENGAN HANYA BACA memungkinkan pembuatan tampilan yang hanya-baca. Anda tidak dapat menggunakan perintah DELETE, INSERT, atau UPDATE untuk mengubah data untuk tampilan hanya-baca.
Klausul WITH CHECK OPTION memungkinkan pembaruan baris yang dapat dipilih melalui view. Klausa WITH CHECK OPTION juga memungkinkan Anda untuk menentukan batasan pada nilai. Klausa CONSTRAINT bekerja bersama dengan klausa WITH CHECK OPTION untuk memungkinkan administrator database menetapkan nama yang unik ke CHECK OPTION. Jika administrator database menghilangkan klausa CONSTRAINT, Oracle akan secara otomatis menetapkan batasan nama yang dihasilkan sistem yang tidak akan terlalu berarti.
Jenis Tampilan
Tampilan sederhana dibuat di atas satu tabel saja, ini adalah kueri SELECT sederhana tanpa fungsi atau klausa grup, tetapi hanya pemilihan kolom dari tabel tanpa transformasi apa pun.Jika DML dilakukan pada tampilan, itu langsung tercermin di tabel dasar.
Tampilan Kompleks dibuat pada beberapa tabel menggunakan gabungan. Tampilan dapat berisi fungsi SQL, Kelompokkan menurut fungsi. Tetapi karena tampilan pada beberapa data dan pemilihan kolom juga tidak sederhana, operasi DML tidak memungkinkan.
Ilustrasi
Simple View: Tampilan sederhana di bawah ini pilih nama karyawan, id departemen dan gaji untuk karyawan dengan JOB ID sebagai DEV.
CREATE OR REPLACE VIEW v_emp_dev
AS
SELECT first_name, department_id, salary
FROM employees
WHERE job_id = 'DEV';
Complex view: Contoh di bawah ini menunjukkan nama departemen, gaji rata-rata yang diambil di departemen dan jumlah karyawan yang bekerja di dalamnya.
CREATE OR REPLACE VIEW EMP_VU
AS
SELECT department_name, AVG (salary) avg_sal, COUNT (first_name) count
FROM employees E, departments D
WHERE E.department_id = D.department_id
GROUP BY department_name;
DESCRIBE [view name]menjelaskan struktur tampilan. Kolom dicantumkan dalam urutan yang sama seperti dalam definisi tampilan.
Operasi DML pada View
Operasi DML dapat dengan mudah dilakukan pada tampilan sederhana Seperti yang dinyatakan sebelumnya, operasi penyisipan, pembaruan, dan penghapusan sebenarnya terjadi pada tabel dasar.
Saat Anda menjalankan pernyataan UPDATE, DELETE, atau INSERT DML pada tampilan, Anda sebenarnya memanipulasi baris data untuk tabel atau tabel dasar tempat tampilan tersebut ditentukan. Ada batasan penggunaan pernyataan UPDATE, DELETE, dan INSERT Pertama, untuk menggunakan pernyataan UPDATE, DELETE, atau INSERT dengan tampilan, tampilan harus dapat diperbarui. Tampilan dapat diperbarui jika klausa SELECT tidak menentukan fungsi agregat apa pun dalam daftar SELECT. Selain itu, tampilan tidak bisa telah dibuat melalui penggunaan klausa atau klausa GROUP BY, DISTINCT, atau UNION. Fungsi agregat diizinkan untuk digunakan dalam subkueri SELECT dalam klausa FROM. Selain itu, tampilan tidak dapat memiliki kolom turunan apa pun dalam daftar PILIH. Selanjutnya, jika tampilan dibuat sebagai hasil dari operasi JOIN (tampilan gabungan), pernyataan UPDATE dan INSERT hanya dapat mengubah atau menyisipkan baris ke salah satu tabel dasar pada satu waktu. Anda tidak dapat mengubah baris dari dua atau lebih tabel dengan satu pernyataan bahasa manipulasi data (DML). Akhirnya, pernyataan DELETE hanya dapat dijalankan terhadap tampilan jika tabel direferensikan dalam klausa FROM. Ini berarti Anda tidak dapat menghapus baris dari tabel yang belum ditentukan.
DENGAN klausa CHECK OPTION
WITH CHECK OPTION adalah klausa opsional yang menentukan tingkat pemeriksaan yang harus dilakukan saat memasukkan atau memperbarui data melalui view. Jika tampilan dibuat menggunakan klausa WITH CHECK OPTION, setiap baris yang disisipkan atau diperbarui di tabel dasar melalui tampilan harus sesuai dengan definisi tampilan. Perhatikan bahwa opsi tidak dapat ditentukan jika tampilan dibuat sebagai baca-saja.
Misalnya, tampilan V_EMP_DEV dibuat untuk karyawan yang merupakan pengembang (JOB_ID = DEV).
CREATE OR REPLACE VIEW v_emp_dev
AS
SELECT first_name, department_id, salary,
FROM employees
WHERE job_id = 'DEV'
WITH CHECK OPTION empvu_dev;
Seorang pengguna mencoba untuk memperbarui gaji karyawan HR melalui tampilan tetapi menemukan pengecualian. Itu karena tampilan itu dibuat DENGAN PILIHAN PERIKSA.
UPDATE v_emp_dev
SET salary = salary+500
WHERE JOB_ID = 'HR';
ORA-01402: view WITH CHECK OPTION where-clause violation
Jika itu hanya tampilan sederhana, pernyataan UPDATE tidak akan memunculkan pengecualian apa pun.
Menjatuhkan tampilan
Administrator database (DBA) atau pemilik tampilan dapat melepaskan tampilan dengan pernyataan DROP VIEW. Jika tampilan memiliki batasan yang ditentukan, Anda perlu menentukan klausa CASCADE CONSTRAINTS saat menghapus tampilan; jika tidak, pernyataan DROP VIEW gagal untuk diproses. Jika tampilan lain atau objek database lain seperti sinonim atau tampilan terwujud (kedua objek ini akan dibahas nanti dalam bab ini) merujuk pada tampilan yang jatuh, Oracle tidak akan menjatuhkan objek database ini; melainkan, Oracle menandainya sebagai tidak valid. Anda dapat menghapus objek yang tidak valid ini atau mendefinisikannya kembali untuk membuatnya valid lagi.
Perintah DROP VIEW di bawah ini menjatuhkan tampilan EMP_VU dari database.
DROP VIEW EMP_VU;
Urutan
Oracle menyediakan kemampuan untuk menghasilkan urutan angka unik untuk jenis penggunaan ini, dan itu disebut urutan. Umumnya, urutan digunakan untuk menghasilkan nilai integer berurutan yang unik yang digunakan sebagai nilai kunci utama dalam tabel database. dibuat dalam urutan naik atau turun. Perhatikan bahwa angka yang dibuat oleh urutan tidak dapat dibatalkan.
Sintaksis
CREATE SEQUENCE <sequence name>
[INCREMENT BY < number >]
[START WITH < start value number>]
[MAXVALUE < MAXIMUM VLAUE NUMBER>]
[NOMAXVALUE]
[MINVALUE < minimum value number>]
[CYCLE | NOCYCLE]
[CACHE < number of sequence value to cache> | NOCACHE]
[ORDER | NOORDER];
Dari sintaks,
Pernyataan CREATE SEQUENCE harus menentukan nama urutan yang unik. Ini adalah satu-satunya klausa yang diperlukan dalam pernyataan tersebut. Jika Anda tidak menentukan klausa lainnya, semua nomor urut yang dihasilkan akan mengikuti pengaturan default Oracle.
Klausa INCREMENT BY menentukan bagaimana urutan bertambah karena setiap angka dihasilkan. Kenaikan default adalah satu; Namun, jika Anda memiliki alasan yang tepat untuk suatu urutan untuk melewati angka, Anda dapat menentukan kenaikan yang berbeda. Peningkatan angka positif menghasilkan angka urutan naik dengan interval yang sama dengan interval yang Anda pilih. Peningkatan angka negatif menghasilkan angka urutan turun.
Klausa START WITH menentukan nilai numerik awal untuk urutan-nomor awal default adalah satu. Selain itu, Anda harus menentukan nilai awal jika Anda sudah memiliki beberapa baris dengan data di kolom yang sekarang akan menyimpan nilai urutan.
Klausa MAXVALUE menentukan nilai maksimum yang dapat ditingkatkan urutannya. Jika MAXVALUE tidak ada, nilai maksimum yang diperbolehkan yang dapat dihasilkan untuk suatu urutan cukup besar, 10 pangkat 27 - 1. Standarnya adalah NOMAXVALUE.
Klausa MINVALUE menentukan nilai minimum urutan untuk urutan penurunan (yang menghasilkan angka dalam urutan menurun). Standarnya adalah NOMINVALUE.
Klausa CYCLE menentukan bahwa nilai urutan dapat digunakan kembali jika urutan mencapai MAXVALUE yang ditentukan. Jika urutan siklus, angka dihasilkan mulai lagi pada nilai MULAI DENGAN.
Klausa CACHE dapat meningkatkan kinerja sistem dengan memungkinkan Oracle menghasilkan kumpulan nomor urut tertentu untuk disimpan dalam memori cache.
Jika Anda menentukan CACHE tanpa menentukan nomor, ukuran cache default adalah 20 nomor urut. Secara opsional, Anda dapat menentukan NOCACHE untuk mencegah cache nomor urut.
Klausa ORDER menentukan bahwa nomor urut dialokasikan dalam urutan kronologis yang tepat seperti yang diminta.
NEXTVAL dan CURRVAL
Nilai urutan dihasilkan melalui penggunaan dua kolom semu bernama currval dan nextval. Kolom semu berperilaku seperti kolom tabel, tetapi kolom semu sebenarnya tidak disimpan dalam tabel. Pertama kali Anda memilih kolom semu nextval, nilai awal di urutan dikembalikan Pilihan berikutnya dari kolom pseudo nextval menyebabkan urutan bertambah seperti yang ditentukan dalam klausa INCREMENT BY dan mengembalikan nilai urutan yang baru dihasilkan Kolom semu saat ini mengembalikan nilai urutan saat ini, yang merupakan nilai yang dikembalikan oleh referensi terakhir untuk nextval.
Dalam sesi, NEXTVAL, dan bukan CURRVAL, harus menjadi tindakan pertama dalam urutan tersebut. Ini karena dalam sebuah sesi, ketika NEXTVAL menghasilkan nomor sesi pertama dari urutan, Oracle menyimpan nilai saat ini di CURRVAL.
Sintaksis:
Sequence.NEXTVAL
Sequence.CURRVAL
Poin yang perlu diperhatikan -
CURRVAL dan NEXTVAL hanya dapat digunakan di SQL Luar dari pernyataan pilih.
CURRVAL dan NEXTVAL dapat digunakan dalam pernyataan INSERT untuk menggantikan kunci primer kolom. Dapat digunakan baik sebagai klausa subquery dan juga dalam klausa VALUES.
CURRVAL dan NEXTVAL dapat digunakan untuk memperbarui nilai di tabel.
CURRVAL dan NEXTVAL tidak boleh ada dalam daftar pilih VIEW, dengan kata kunci DISTINCT, dengan klausa GROUP BY, HAVING, atau ORDER BY, dan ekspresi DEFAULT dalam pernyataan CREATE TABLE atau ALTER TABLE.
Mengubah urutan
Pemilik urutan dapat memodifikasi urutan untuk mengubah atribut seperti klausa INCREMENT BY, MINVALUE, MAXVALUE, CYCLE, atau CACHE saja. Perhatikan bahwa perubahan yang dilakukan akan tercermin dalam nomor yang akan datang.
Sintaksis:
ALTER SEQUENCE [sequence name]
INCREMENT BY n
MAXVALUE n
NOCACHE
NOCYCLE
Menghapus urutannya
Perintah DROP SEQUENCE menghilangkan urutan yang perlu dibuat ulang atau tidak lagi diperlukan.
DROP SEQUENCE [sequence name]
Indeks
Indeks adalah objek database yang digunakan untuk menyetel kinerja kueri SELECT. Ada berbagai jenis indeks termasuk yang digunakan untuk menerapkan batasan kunci utama, indeks unik, indeks non-unik, dan indeks gabungan, antara lain. Tanpa indeks, kueri akan mengharuskan Oracle untuk memindai semua baris dalam tabel untuk mengembalikan baris yang diperlukan untuk tabel hasil. Indeks dibuat pada kolom tabel, yang kemudian menyimpan semua nilai kolom di bawah segmen indeks. Tidak seperti urutan, indeks adalah tabel spesifik. Mereka secara otomatis dijatuhkan setelah tabel dijatuhkan.
Indeks dapat dibuat secara otomatis atau manual. Saat Anda menentukan batasan PRIMARY KEY atau UNIQUE, Oracle akan secara otomatis membuat indeks unik untuk mendukung pengambilan data cepat untuk tabel yang ditentukan.
Alternatifnya, pengguna dapat membuat indeks secara manual untuk mengoptimalkan kinerja query. Indeks yang dibuat secara manual bisa unik atau tidak unik Indeks non-unik dapat berupa indeks berbasis B-Tree, Bitmap atau Fungsi. Secara default, Oracle membuat indeks B-Tree pada kolom Berikut sintaksnya
Sintaksis
CREATE [UNIQUE][BITMAP]INDEX index
ON table (column [, column]...);
Perhatikan bahwa UNIQUE dan BITMAP harus ditentukan hanya untuk indeks unik dan bitmap. Secara default, Oracle membuat indeks B-Tree untuk indeks normal.
Indeks komposit (juga disebut indeks gabungan) adalah indeks yang dibuat di beberapa kolom tabel. Kolom dalam indeks komposit dapat muncul dalam urutan apa pun dan tidak perlu kolom yang berdekatan dalam tabel. Indeks komposit meningkatkan kecepatan pengambilan baris untuk kueri di mana klausa WHERE mereferensikan semua atau bagian utama kolom dalam indeks komposit. Indeks dapat berisi maksimal 32 kolom.
Misalnya, seorang pengguna membuat indeks IDX_EMP pada kolom HIRE_DATE dari tabel EMPLOYEES. Penggunaan indeks akan mengurangi I / O disk dengan melintasi pemindaian jalur yang diindeks dan menemukan data yang difilter pada kolom HIRE_DATE.
CREATE INDEX IDX_EMP ON employees(hire_date);
Menjatuhkan Indeks
Indeks tidak dapat dimodifikasi tetapi dapat diubah untuk keperluan analisis, pembangunan kembali atau perhitungan statistik. Jika definisi indeks harus dimodifikasi, itu harus dihapus dan dibuat ulang. Sintaks dari perintah DROP INDEX sederhana.
DROP INDEX index_name;
Sinonim
Sinonim adalah alias, yaitu bentuk singkatan yang digunakan untuk menyederhanakan tugas mereferensikan objek database. Konsepnya analog dengan penggunaan nama panggilan untuk teman dan kenalan. Merujuk objek yang dimiliki oleh pengguna lain memerlukan nama skema untuk diawali dengan itu. Dengan bantuan sinonim, Anda mengurangi upaya mereferensikan objek bersama dengan nama skema. Dengan cara ini, sinonim memberikan transparansi lokasi karena nama sinonim menyembunyikan nama objek yang sebenarnya dan pemiliknya.
Ada dua kategori sinonim, publik dan privat. Sinonim publik dapat digunakan untuk memungkinkan akses mudah ke suatu objek untuk semua pengguna sistem. Faktanya, individu yang membuat sinonim publik tidak memiliki sinonim-melainkan, itu akan menjadi milik grup pengguna PUBLIK yang ada di dalam Oracle. Sinonim pribadi, di sisi lain, milik pengguna sistem yang membuatnya dan berada di dalamnya skema pengguna.
Sintaksis
CREATE [PUBLIC] SYNONYM [synonym name]
FOR OBJECT;
Pengguna sistem dapat memberikan hak istimewa untuk menggunakan sinonim privat yang mereka miliki untuk pengguna sistem lain.Untuk membuat sinonim, Anda harus memiliki hak istimewa CREATE SYNONYM. Lebih lanjut, Anda harus memiliki hak istimewa CREATE PUBLIC SYNONYM untuk membuat sinonim publik Jika sinonim dideklarasikan sebagai publik, nama sinonim tersebut tidak dapat digunakan sebagai sinonim publik. Mencoba membuat sinonim publik yang sudah ada akan menyebabkan perintah CREATE PUBLIC SYNONYM gagal, dan Oracle akan mengembalikan ORA-00955: nama sudah digunakan oleh pesan kesalahan objek yang ada.
Ilustrasi
Pertimbangkan dua pengguna U1 dan U2.U1 memiliki akses ke tabel EMPLOYEES. Jadi untuk mengaktifkan akses pada tabel EMPLOYEES ke U2 juga, sinonim dapat dibuat dalam skema U2. Akses harus diberikan oleh U1 hingga U2.
CONN U2/U2
SQL> CREATE SYNONYM EMP_SYN FOR U1.employees;
CONN U1/U1
SQL> GRANT ALL ON EMP_SYN TO U2;
CONN U2/U2
SQL> SELECT * FROM EMP_SYN;
Menjatuhkan Sinonim
Seorang uer dapat menghilangkan sinonim yang dimilikinya. Untuk menghapus sinonim publik, Anda harus memiliki hak istimewa DROP PUBLIC SYNONYM.
DROP SYNONYM EMP_SYN;