Menggunakan Pernyataan DDL
Menggunakan Pernyataan DDL untuk Membuat dan Mengelola Tabel
Skema adalah kumpulan beberapa objek database, yang dikenal sebagai objek skema. Objek-objek ini memiliki akses langsung oleh skema pemiliknya. Tabel di bawah mencantumkan objek skema.
Tabel - untuk menyimpan data
Lihat - untuk memproyeksikan data dalam format yang diinginkan dari satu atau beberapa tabel
Urutan - untuk menghasilkan nilai numerik
Indeks - untuk meningkatkan kinerja kueri pada tabel
Sinonim - nama alternatif dari suatu objek
Salah satu langkah pertama dalam membuat database adalah membuat tabel yang akan menyimpan data organisasi. Desain database melibatkan identifikasi kebutuhan pengguna sistem untuk berbagai sistem organisasi seperti entri pesanan, manajemen inventaris, dan piutang. Terlepas dari ukuran dan kompleksitas database, setiap database terdiri dari tabel.
Membuat meja
Untuk membuat tabel dalam database, DBA harus memiliki informasi tertentu - nama tabel, nama kolom, tipe data kolom, dan ukuran kolom. Semua informasi ini dapat diubah nanti menggunakan perintah DDL.
Konvensi Penamaan Tabel -
Nama yang Anda pilih untuk tabel harus mengikuti aturan standar berikut:
Nama harus dimulai dengan huruf AZ atau az
Dapat berisi angka dan garis bawah
Bisa di UPPER huruf kecil
Panjangnya bisa sampai 30 karakter
Tidak dapat menggunakan nama yang sama dari objek lain yang sudah ada dalam skema Anda
Tidak boleh berupa kata khusus SQL
Mengikuti pedoman di atas, 'EMP85' dapat menjadi nama tabel yang valid, tetapi 85EMP tidak. Demikian pula, UPDATE tidak dapat dipilih sebagai nama tabel karena merupakan kata kunci khusus SQL.
Pernyataan CREATE TABLE
CREATE TABLE adalah pernyataan DDL yang digunakan untuk membuat tabel dalam database. Tabel dibuat segera setelah skrip CREATE TABLE dijalankan dan siap untuk menyimpan datanya. Pengguna harus memiliki hak istimewa sistem CREATE TABLE untuk membuat tabel dalam skema sendiri. Tetapi untuk membuat tabel dalam skema pengguna mana pun, pengguna harus memiliki skema CREATE ANY TABLE.
Berikut adalah sintaks dari pernyataan CREATE TABLE dasar. Mungkin ada banyak klausul tambahan untuk secara eksplisit memberikan spesifikasi penyimpanan atau nilai segmen.
CREATE TABLE [schema.]table
( { column datatype [DEFAULT expr] [column_constraint] ...
| table_constraint}
[, { column datatype [DEFAULT expr] [column_constraint] ...
| table_constraint} ]...)
[AS subquery]
Dalam sintaks di atas, DEFAULT menentukan nilai default yang dapat digunakan selama pernyataan INSERT jika kolom diabaikan. Ini tidak bisa berisi referensi ke kolom tabel lain atau kolom semu (CURRVAL, NEXTVAL, LEVEL, dan ROWNUM) kecuali SYSDATE dan USER, atau konstanta tanggal yang tidak sepenuhnya ditentukan.
Batasan adalah aturan yang didefinisikan secara opsional di tingkat kolom atau tingkat tabel (dibahas nanti dalam bab ini). Aturan ini diperiksa selama tindakan data apa pun (Sisipkan, perbarui) pada tabel dan meningkatkan kesalahan untuk membatalkan tindakan atas pelanggarannya.
Misalnya, pernyataan CREATE TABLE di bawah ini membuat tabel EMP_TEST. Perhatikan spesifikasi kolom, tipe data dan presisi.
CREATE TABLE SCOTT.EMP_TEST
(EMPID NUMBER,
ENAME VARCHAR2(100),
DEPARTMENT_ID NUMBER,
SALARY NUMBER,
JOB_ID VARCHAR2(3),
HIREDATE DATE,
COMM NUMBER);
Seorang pengguna dapat merujuk tabel dari skema pengguna lain dengan memberi awalan nama pengguna atau skema dengan nama tabel. Sebagai contoh, seorang pengguna GUEST ingin menanyakan nama dan gaji karyawan dari tabel EMP_TEST yang dimiliki oleh SCOTT. Dia dapat mengeluarkan pertanyaan di bawah ini -
SELECT ENAME, SALARY,
FROM GUEST.EMP_TEST;
Sebuah kolom dapat menampung nilai default selama waktu pembuatan tabel. Ini membantu membatasi nilai NULL yang masuk ke kolom. Nilai default dapat disimpulkan baik dari fungsi literal, ekspresi atau SQL yang harus mengembalikan tipe data yang kompatibel ke kolom. Dalam pernyataan CREATE TABLE di bawah ini, perhatikan bahwa kolom LOCATION_ID memiliki nilai default 100.
CREATE TABLE SCOTT.DEPARTMENT
(DEPARTMENT_ID NUMBER,
DNAME VARCHAR2 (100),
LOCATION_ID NUMBER DEFAULT 100);
CTAS - Buat tabel menggunakan subquery
Tabel dapat dibuat dari tabel yang sudah ada di database menggunakan opsi subquery, yang menyalin struktur tabel serta data dari tabel. Data juga dapat disalin berdasarkan kondisi. Definisi tipe data kolom termasuk batasan NOT NULL yang diberlakukan secara eksplisit disalin ke dalam tabel baru.
Skrip CTAS di bawah ini membuat tabel baru EMP_BACKUP. Data karyawan departemen 20 disalin ke tabel baru.
CREATE TABLE EMP_BACKUP
AS
SELECT * FROM EMP_TEST
WHERE department_id=20;
Tipe data
Tipe data digunakan untuk menentukan perilaku dasar kolom dalam tabel. Secara lebih luas, perilaku kolom dapat dimiliki oleh angka, karakter, atau keluarga tanggal. Ada beberapa subtipe lain yang termasuk dalam keluarga ini.
Tipe data angka
Tipe data NOMOR mencakup nilai numerik integer, fixed-point, dan floating-point. Versi awal Oracle mendefinisikan tipe data yang berbeda untuk masing-masing tipe angka yang berbeda ini, tetapi sekarang tipe data NUMBER melayani semua tujuan ini. Pilih tipe data NUMBER ketika kolom harus menyimpan data numerik yang dapat digunakan dalam perhitungan matematis. Kadang-kadang, tipe data NOMOR digunakan untuk menyimpan nomor identifikasi di mana nomor tersebut dihasilkan oleh DBMS sebagai nomor urut.
NOMOR (p, s), di mana p adalah ketelitian hingga 38 digit dan s adalah skala (jumlah digit di sebelah kanan koma desimal). Skala dapat berkisar antara -84 hingga 127.
NOMOR (p), adalah bilangan titik tetap dengan skala nol dan presisi p.
FLOAT [(p)], di mana p adalah presisi biner yang dapat berkisar dari 1 hingga 126. Jika p tidak ditentukan, nilai defaultnya adalah biner 126.
Tipe data tanggal
Untuk setiap tipe data DATE, Century, Year, Month, Day, Hour, Minute, Second disimpan dalam database. Setiap sistem database memiliki format tanggal default yang ditentukan oleh parameter inisialisasi NLS_DATE_FORMAT. Parameter ini biasanya diatur ke DD-MON-YY. Jika Anda tidak menentukan waktu, waktu default adalah 12:00:00
Tipe data karakter
Oracle mendukung tiga tipe data karakter yang telah ditentukan termasuk CHAR, VARCHAR, VARCHAR2, dan LONG. VARCHAR dan VARCHAR2 sebenarnya sama, dan Oracle merekomendasikan penggunaan VARCHAR2 daripada VARCHAR. Gunakan tipe data CHAR ketika kolom akan menyimpan nilai karakter dengan panjang tetap. Misalnya, nomor Jaminan Sosial (SSN) di Amerika Serikat ditetapkan untuk setiap warga negara dan selalu berukuran 9 karakter (meskipun SSN hanya terdiri dari digit, digit tersebut diperlakukan sebagai karakter), dan akan ditetapkan sebagai CHAR (9). Gunakan tipe data VARCHAR2 untuk menyimpan data alfanumerik dengan panjang variabel. Misalnya, nama atau alamat pelanggan akan sangat bervariasi dalam hal jumlah karakter yang akan disimpan.Ukuran maksimum kolom VARCHAR2 adalah 4.000 karakter.
Tipe data LOB
Oracle menyediakan beberapa tipe data LOB yang berbeda, termasuk CLOB (karakter objek besar) dan BLOB (objek besar biner). Kolom tipe data ini dapat menyimpan data tidak terstruktur termasuk teks, gambar, video, dan data spasial. Tipe data CLOB dapat menyimpan hingga delapan terabyte data karakter menggunakan kumpulan karakter basis data CHAR. Jenis data BLOB digunakan untuk menyimpan objek besar biner tak terstruktur seperti yang terkait dengan data gambar dan video di mana datanya hanyalah aliran nilai "bit". Jenis data BLOB dapat menyimpan hingga delapan terabyte data biner. Tipe data NCLOB dapat menyimpan karakter objek besar dalam pengaturan karakter nasional multibyte hingga 8TB hingga 128TB. Nilai tipe data BFILE berfungsi sebagai pencari file atau penunjuk ke file di sistem file server. Ukuran file maksimum yang didukung adalah 8TB hingga 128TB.
Kendala
Batasan adalah sekumpulan aturan yang ditentukan dalam tabel Oracle untuk memastikan integritas data. Aturan ini diterapkan untuk setiap kolom atau kumpulan kolom. Kapan pun tabel berpartisipasi dalam tindakan data, aturan ini divalidasi dan meningkatkan pengecualian jika terjadi pelanggaran. Jenis kendala yang tersedia adalah NOT NULL, Primary Key, Unique, Check, dan Foreign Key.
Sintaks di bawah ini dapat digunakan untuk memaksakan batasan pada tingkat kolom.
Sintaksis:
column [data type] [CONSTRAINT constraint_name] constraint_type
Semua batasan kecuali NOT NULL, juga dapat didefinisikan di tingkat tabel. Batasan komposit hanya dapat ditentukan di tingkat tabel.
NOT NULL Constraint
Batasan NOT NULL berarti bahwa baris data harus memiliki nilai untuk kolom yang ditentukan sebagai NOT NULL. Jika kolom ditentukan sebagai NOT NULL, Oracle RDBMS tidak akan mengizinkan baris untuk disimpan ke tabel karyawan yang melanggar batasan ini. hanya dapat ditentukan di tingkat kolom, dan bukan di tingkat tabel.
Sintaksis:
COLUMN [data type] [NOT NULL]
Kendala UNIK
Terkadang perlu untuk menerapkan keunikan untuk nilai kolom yang bukan kolom kunci utama. Batasan UNIQUE dapat digunakan untuk memberlakukan aturan ini dan Oracle akan menolak setiap baris yang melanggar batasan unik. Batasan unik memastikan bahwa nilai kolom berbeda , tanpa duplikat.
Sintaksis:
Column Level:
COLUMN [data type] [CONSTRAINT <name>] [UNIQUE]
Table Level: CONSTRAINT [nama batasan] UNIK (nama kolom)
Catatan: Oracle secara internal membuat indeks unik untuk mencegah duplikasi dalam nilai kolom. Indeks akan dibahas nanti di PL / SQL.
CREATE TABLE TEST
( ... ,
NAME VARCHAR2(20)
CONSTRAINT TEST_NAME_UK UNIQUE,
... );
Dalam kasus kunci unik komposit, itu harus ditentukan pada tingkat tabel seperti di bawah ini.
CREATE TABLE TEST
( ... ,
NAME VARCHAR2(20),
STD VARCHAR2(20) ,
CONSTRAINT TEST_NAME_UK UNIQUE (NAME, STD)
);
Kunci utama
Setiap tabel biasanya harus berisi kolom atau kumpulan kolom yang secara unik mengidentifikasi baris data yang disimpan dalam tabel. Kolom atau kumpulan kolom ini disebut sebagai kunci utama. Sebagian besar tabel memiliki satu kolom sebagai kunci utama. kolom kunci dibatasi terhadap NULL dan nilai duplikat.
Poin yang perlu diperhatikan -
Tabel hanya dapat memiliki satu kunci utama.
Beberapa kolom dapat dipukuli di bawah kunci utama komposit.
Oracle secara internal membuat indeks unik untuk mencegah duplikasi dalam nilai kolom. Indeks akan dibahas nanti di PL / SQL.
Sintaksis:
Column level:
COLUMN [data type] [CONSTRAINT <constraint name> PRIMARY KEY]
Table level:
CONSTRAINT [constraint name] PRIMARY KEY [column (s)]
Contoh berikut menunjukkan bagaimana menggunakan batasan PRIMARY KEY di tingkat kolom.
CREATE TABLE TEST
( ID NUMBER CONSTRAINT TEST_PK PRIMARY KEY,
... );
Contoh berikut menunjukkan cara mendefinisikan kunci utama komposit menggunakan batasan PRIMARY KEY di tingkat tabel.
CREATE TABLE TEST
( ...,
CONSTRAINT TEST_PK PRIMARY KEY (ID)
);
Kunci asing
Ketika dua tabel berbagi hubungan induk anak berdasarkan kolom tertentu, kolom yang bergabung dalam tabel anak dikenal sebagai Kunci Asing Properti dari kolom yang sesuai dalam tabel induk ini dikenal sebagai integritas referensial. Nilai kolom Kunci Asing di tabel anak dapat nihil atau harus berupa nilai tabel induk yang ada. Harap diperhatikan bahwa hanya kolom kunci utama dari tabel yang direferensikan yang memenuhi syarat untuk menerapkan integritas referensial.
Jika foreign key didefinisikan pada kolom dalam tabel anak maka Oracle tidak mengizinkan baris induk untuk dihapus, jika baris tersebut berisi baris anak apapun.Namun, jika opsi ON DELETE CASCADE diberikan pada saat mendefinisikan foreign key, Oracle menghapus semua baris anak sementara baris induk sedang dihapus. Demikian pula, ON DELETE SET NULL menunjukkan bahwa ketika baris dalam tabel induk dihapus, nilai kunci asing disetel ke nol.
Sintaksis:
Column Level:
COLUMN [data type] [CONSTRAINT] [constraint name] [REFERENCES] [table name (column name)]
Table level:
CONSTRAINT [constraint name] [FOREIGN KEY (foreign key column name) REFERENCES] [referenced table name (referenced column name)]
Contoh berikut menunjukkan bagaimana menggunakan batasan FOREIGN KEY di tingkat kolom.
CREATE TABLE TEST
(ccode varchar2(5)
CONSTRAINT TEST_FK REFERENCES PARENT_TEST(ccode),
...
);
Usage of ON DELETE CASCADE clause
CREATE TABLE TEST
(ccode varchar2(5)
CONSTRAINT TEST_FK REFERENCES PARENT_TEST (ccode)
ON DELETE CASCADE,
...
);
Periksa kendala
Kadang-kadang nilai data yang disimpan dalam kolom tertentu harus berada dalam beberapa rentang nilai yang dapat diterima. Batasan PERIKSA mengharuskan kondisi pemeriksaan yang ditentukan benar atau tidak diketahui untuk setiap baris yang disimpan dalam tabel. Batasan pemeriksaan memungkinkan untuk menerapkan aturan bersyarat pada sebuah kolom, yang harus divalidasi sebelum data dimasukkan ke dalam kolom. Kondisi tidak boleh berisi sub query atau kolom semu CURRVAL NEXTVAL, LEVEL, ROWNUM, atau SYSDATE.
Oracle mengizinkan satu kolom untuk memiliki lebih dari satu kendala PERIKSA. Faktanya, tidak ada batasan praktis untuk jumlah batasan PERIKSA yang dapat ditentukan untuk kolom.
Sintaksis:
Column level:
COLUMN [data type] CONSTRAINT [name] [CHECK (condition)]
Table level:
CONSTRAINT [name] CHECK (condition)
Contoh berikut menunjukkan bagaimana menggunakan PERIKSA batasan di tingkat kolom.
CREATE TABLE TEST
( ...,
GRADE char (1) CONSTRAINT TEST_CHK
CHECK (upper (GRADE) in ('A','B','C')),
...
);
Contoh berikut menunjukkan bagaimana menggunakan PERIKSA batasan di tingkat tabel.
CREATE TABLE TEST
( ...,
CONSTRAINT TEST_CHK
CHECK (stdate < = enddate),
);
Pernyataan ALTER TABLE
DBA dapat membuat perubahan pada struktur tabel atau definisi kolom setelah tabel dibuat dalam database. Perintah DDL ALTER TABLE digunakan untuk melakukan tindakan tersebut, Perintah alter menyediakan beberapa utilitas eksklusif untuk objek skema. Pernyataan ALTER TABLE digunakan untuk menambah, melepaskan, mengganti nama, dan mengubah kolom dalam tabel.
Pernyataan ALTER TABLE di bawah ini mengganti nama tabel EMP menjadi EMP_NEW.
ALTER TABLE EMP RENAME TO EMP_NEW;
Pernyataan ALTER TABLE di bawah ini menambahkan kolom baru TESTCOL ke tabel EMP_NEW
ALTER TABLE EMP_NEW ADD (TESTCOL VARCHAR2 (100))
Pernyataan ALTER TABLE di bawah ini mengganti nama kolom TESTCOL menjadi TESTNEW.
ALTER TABLE EMP_NEW RENAME COLUMN TESTCOL TO TESTNEW
Pernyataan ALTER TABLE di bawah ini menghapus kolom TESTNEW dari tabel EMP_NEW
ALTER TABLE EMP_NEW DROP COLUMN TESTNEW;
Pernyataan ALTER TABLE di bawah ini menambahkan kunci utama pada kolom EMPLOYEE_ID.
ALTER TABLE EMP_NEW ADD PRIMARY KEY (EMPLOYEE_ID)
Pernyataan ALTER TABLE di bawah ini menjatuhkan kunci utama.
ALTER TABLE EMP_NEW DROP PRIMARY KEY;
Pernyataan ALTER TABLE di bawah ini mengalihkan mode tabel menjadi hanya baca.
ALTER TABLE EMP_NEW READ ONLY;
Tabel Hanya Baca
Tabel hanya baca datang sebagai peningkatan di Oracle 11g. Ini memungkinkan tabel digunakan untuk tujuan hanya baca. Pada versi oracle sebelumnya, tabel dibuat hanya baca dengan memberikan hak istimewa SELECT kepada pengguna lain, tetapi pemilik masih memiliki hak istimewa baca tulis. Tetapi sekarang, jika tabel disetel sebagai Hanya baca, bahkan pemilik tidak memiliki akses pada manipulasi data .
Sintaksis:
ALTER TALE [TABLE NAME] READ ONLY
ALTER TALE [TABLE NAME] READ WRITE
Ilustrasi
SQL>CREATE TABLE ORATEST (id NUMBER)
SQL>INSERT INTO ORATEST VALUES (1);
SQL>ALTER TABLE ORATEST READ ONLY;
SQL> INSERT INTO ORATEST VALUES (2);
INSERT INTO ORATEST VALUES (2)
*
ERROR at line 1:
ORA-12081: update operation not allowed on table "TEST"."ORATEST"
SQL> UPDATE ORATEST SET id = 2;
UPDATE ORATEST SET id = 2
*
ERROR at line 1:
ORA-12081: update operation not allowed on table "TEST"."ORATEST"
SQL> DELETE FROM ORATEST;
DELETE FROM ORATEST
*
ERROR at line 1:
ORA-12081: update operation not allowed on table "TEST"."ORATEST"
SQL> TRUNCATE TABLE ORATEST;
TRUNCATE TABLE ORATEST
*
ERROR at line 1:
ORA-12081: update operation not allowed on table "TEST"."ORATEST"
SQL> ALTER TABLE ORATEST ADD (description VARCHAR2 (50));
ALTER TABLE ORATEST ADD (description VARCHAR2 (50))
*
ERROR at line 1:
ORA-12081: update operation not allowed on table "TEST"."ORATEST"
SQL> ALTER TABLE ORATEST READ WRITE;
Table altered.
SQL> DELETE FROM ORATEST;
1 row deleted.
Pernyataan DROP TABLE
Pernyataan DROP TABLE digunakan untuk menghapus tabel dari database. Tabel yang dihapus dan datanya tetap tidak lagi tersedia untuk dipilih. Tabel yang dihapus dapat dipulihkan menggunakan utilitas FLASHBACK, jika tersedia di recyclebin. Menghapus tabel akan menghilangkan indeks dan pemicu yang terkait dengannya.
Sintaksis:
DROP TABLE [TABLE NAME] [PURGE]
Pernyataan di bawah ini akan menjatuhkan tabel dan menempatkannya di recyclebin.
DROP TABLE emp_new;
Pernyataan di bawah ini akan menghilangkan tabel dan membuangnya dari recyclebin juga.
DROP TABLE emp_new PURGE;