Menggunakan Memanipulasi Data

Oracle menyediakan perintah Data Manipulation Language untuk menjalankan operasi data dalam database. Operasi data dapat mengisi tabel database dengan aplikasi atau data bisnis, memodifikasi data dan menghapus data dari database, kapan pun diperlukan. Selain operasi data, ada sekumpulan perintah yang digunakan untuk mengontrol operasi ini, yang dikelompokkan sebagai Transaction Control Language.

Ada tiga jenis pernyataan DML yang terlibat dalam transaksi SQL logis yaitu, Sisipkan, Perbarui, Hapus, dan Gabungkan. Transaksi adalah kumpulan logis tindakan DML dalam sesi database.

Pernyataan INSERT

Perintah INSERT digunakan untuk menyimpan data dalam tabel. Perintah INSERT sering digunakan dalam bahasa pemrograman tingkat tinggi seperti Visual Basic.NET atau C ++ sebagai perintah SQL yang disematkan; Namun, perintah ini juga dapat dijalankan pada prompt SQL * PLUS dalam mode perintah. Ada dua bentuk berbeda dari perintah INSERT. Formulir pertama digunakan jika baris baru akan memiliki nilai yang disisipkan ke setiap kolom baris. Bentuk kedua dari perintah INSERT digunakan untuk menyisipkan baris di mana beberapa data kolom tidak diketahui atau default dari logika bisnis lain. Bentuk perintah INSERT ini mengharuskan Anda menentukan nama kolom yang datanya disimpan.

Sintaksis:

Sintaks di bawah ini dapat diikuti jika nilai untuk semua kolom dalam tabel sudah pasti dan diketahui.

INSERT INTO table
VALUES (column1 value, column2 value, 
...);

Sintaks di bawah ini dapat digunakan jika hanya beberapa kolom dari tabel yang harus diisi dengan nilai. Kolom lainnya dapat menyimpulkan nilainya baik sebagai NULL atau dari logika bisnis yang berbeda.

INSERT INTO table (column1 name, column2 name, . . .)
VALUES (column1 value, column2 value, . . .);

Pernyataan INSERT di bawah ini membuat catatan karyawan baru di tabel EMPLOYEES. Perhatikan bahwa ini memasukkan nilai untuk kolom utama EMPLOYEE_ID, FIRST_NAME, SALARY dan DEPARTMENT_ID.

INSERT INTO employees (EMPLOYEE_ID, FIRST_NAME, SALARY, DEPARTMENT_ID)
VALUES (130, 'KEMP', 3800, 10);

Jika tidak, data karyawan yang lengkap dapat dimasukkan ke dalam tabel KARYAWAN tanpa menentukan daftar kolom menggunakan pernyataan INSERT di bawah ini - asalkan nilainya telah diketahui sebelumnya dan harus sesuai dengan tipe data dan posisi kolom di tabel.

INSERT INTO employees
VALUES (130, 'KEMP','GARNER', '[email protected]', '48309290',TO_DATE ('01-JAN-2012'), 'SALES', 3800, 0, 110, 10);

Nilai yang akan disisipkan harus sesuai dengan tipe data kolom. Literal, nilai tetap, dan nilai khusus seperti fungsi, SYSDATE, CURRENT_DATE, SEQ.CURRVAL (NEXTVAL), atau USER dapat digunakan sebagai nilai kolom. Nilai yang ditentukan harus mengikuti aturan umum. Literal string dan nilai tanggal harus diapit dalam tanda kutip. Nilai tanggal dapat diberikan dalam format DD-MON-RR atau D-MON-YYYY, tetapi YYYY lebih disukai karena secara jelas menentukan abad dan tidak bergantung pada logika penghitungan abad RR internal.

INSERT-AS-SELECT (IAS)

Data dapat diisi ke dalam tabel target dari tabel sumber menggunakan operasi INSERT..AS..SELECT (IAS). Ini adalah operasi pembacaan jalur langsung.Ini cara sederhana untuk membuat salinan data dari satu tabel ke tabel lain atau membuat salinan cadangan tabel yang operasi tabel sumber sedang online.

Misalnya, data dapat disalin dari tabel EMPLOYEES ke tabel EMP_HISTORY.

INSERT INTO EMP_HISTORY
SELECT EMPLOYEE_ID, EMPLOYEE_NAME, SALARY, DEPARTMENT_ID
FROM employees;

Pernyataan UPDATE

Perintah UPDATE mengubah data yang disimpan dalam kolom. Perintah ini dapat memperbarui satu atau beberapa baris sekaligus tergantung pada kumpulan hasil yang difilter menurut kondisi yang ditentukan dalam klausa WHERE Perhatikan bahwa memperbarui kolom berbeda dengan mengubah kolom. Sebelumnya di bab ini, Anda telah mempelajari perintah ALTER. Perintah ALTER mengubah struktur tabel, tetapi membiarkan data tabel tidak terpengaruh. Perintah UPDATE mengubah data dalam tabel, bukan struktur tabel.

Sintaksis:

UPDATE table
SET column = value [, column = value ...]
[WHERE condition]

Dari sintaks,

Kolom SET = ekspresi dapat berupa kombinasi karakter, rumus, atau fungsi apa pun yang akan memperbarui data dalam nama kolom yang ditentukan.Klausul WHERE bersifat opsional, tetapi jika disertakan, ini menentukan baris mana yang akan diperbarui.Hanya satu tabel yang dapat diperbarui pada suatu waktu dengan perintah UPDATE.

Pernyataan UPDATE di bawah ini memperbarui gaji karyawan JOHN menjadi 5.000.

UPDATE employees
SET salary = 5000
WHERE UPPER (first_name) = 'JOHN';

Meskipun predikat WHERE bersifat opsional, tetapi harus ditambahkan secara logis sehingga hanya dapat mengubah baris yang diperlukan dalam tabel. Pernyataan UPDATE di bawah ini memperbarui gaji semua karyawan di tabel.

UPDATE employees
SET salary = 5000;

Beberapa kolom juga dapat diperbarui dengan menentukan beberapa kolom dalam klausa SET yang dipisahkan dengan koma. Misalnya, jika gaji dan peran pekerjaan harus diubah menjadi 5000 dan SALES masing-masing untuk JOHN, pernyataan UPDATE terlihat seperti,

UPDATE employees
SET	SALARY = 5000,
	JOB_ID = 'SALES'
WHERE UPPER (first_name) = 'JOHN';

1 row updated.

Cara lain untuk memperbarui beberapa kolom dari baris yang sama menunjukkan penggunaan subkueri.

UPDATE employees
SET (SALARY, JOB_ID) = (SELECT 5000, 'SALES' FROM DUAL)
WHERE UPPER (ENAME) = 'JOHN'

HAPUS pernyataan

Perintah DELETE adalah salah satu pernyataan SQL yang paling sederhana. Ini menghapus satu atau lebih baris dari tabel. Operasi penghapusan beberapa tabel tidak diperbolehkan di SQL. Sintaks dari perintah DELETE adalah seperti di bawah ini.

DELETE FROM table_name
    [WHERE condition];

Perintah DELETE menghapus semua baris dalam tabel yang memenuhi kondisi di klausa WHERE opsional. Karena klausa WHERE bersifat opsional, seseorang dapat dengan mudah menghapus semua baris dari tabel dengan menghilangkan klausa WHERE karena klausa WHERE membatasi cakupan operasi DELETE.

Pernyataan DELETE di bawah ini akan menghapus detail EDWIN dari tabel EMP.

DELETE employees
WHERE UPPER (ENAME) = 'EDWIN'

1 row deleted.

Catatan: HAPUS [NAMA TABEL] dan HAPUS DARI [NAMA TABEL] memiliki arti yang sama.

Kondisi WHERE dalam pernyataan delete bersyarat dapat menggunakan subquery seperti yang ditunjukkan di bawah ini.

DELETE FROM employees
WHERE DEPARTMENT_ID IN (SELECT DEPARTMENT_ID
				    FROM LOCATIONS
				    WHERE LOCATION_CODE = 'SFO')

MEMOTONG

Truncate adalah perintah DDL yang digunakan untuk membersihkan semua record dari tabel tetapi tetap mempertahankan struktur tabel. Itu tidak mendukung kondisi WHERE untuk menghapus rekaman yang dipilih.

Sintaksis:

TRUNCATE [table name]

Ini adalah Komitmen Otomatis, yaitu melakukan transaksi aktif saat ini dalam sesi. Memotong tabel tidak mengurangi indeks dependen, pemicu, atau batasan tabel. Jika tabel A adalah induk dari batasan referensi dari tabel B dalam database, tabel A tidak dapat dipotong.

Transaksi

Transaksi adalah unit logis dari pekerjaan yang dilakukan dalam database. Ini bisa berisi -

  • Beberapa perintah DML diakhiri dengan perintah TCL yaitu COMMIT atau ROLLBACK

  • Satu perintah DDL

  • Satu perintah DCL

Awal transaksi ditandai dengan perintah DML pertama. Ini diakhiri dengan perintah TCL, DDL atau DCL. Perintah TCL yaitu COMMIT atau ROLLBACK adalah masalah yang secara eksplisit mengakhiri transaksi aktif. Berdasarkan perilaku dasarnya, jika ada perintah DDL atau DCL yang dieksekusi dalam sesi database, lakukan transaksi aktif yang sedang berlangsung dalam sesi tersebut. Jika contoh database lumpuh secara tidak normal, transaksi dihentikan.

COMMIT, ROLLBACK dan SAVEPOINT adalah bahasa kontrol transaksi. COMMIT menerapkan perubahan data secara permanen ke dalam database sementara ROLLBACK melakukan operasi anti-commit. SAVEPOINT mengontrol rangkaian transaksi dengan menetapkan penanda pada tahapan transaksi yang berbeda. Pengguna dapat mengembalikan transaksi saat ini ke titik penyimpanan yang diinginkan, yang telah ditetapkan sebelumnya.

COMMIT- Komit mengakhiri transaksi aktif saat ini dengan menerapkan perubahan data secara permanen ke dalam tabel database. COMMIT adalah perintah TCL yang secara eksplisit mengakhiri transaksi. Namun, perintah DDL dan DCL secara implisit melakukan transaksi.

SAVEPOINT- Savepoint digunakan untuk menandai titik tertentu dalam transaksi saat ini di sesi. Karena ini merupakan penanda logis dalam transaksi, savepoint tidak dapat dikueri dalam kamus data.

ROLLBACK- Perintah ROLLBACK digunakan untuk mengakhiri seluruh transaksi dengan membuang perubahan data. Jika transaksi berisi savepoint yang ditandai, ROLLBACK TO SAVEPOINT [nama] dapat digunakan untuk mengembalikan transaksi hingga hanya savepoint yang ditentukan. Akibatnya, semua perubahan data hingga savepoint yang ditentukan akan dibuang.

Demonstrasi

Pertimbangkan tabel EMPLOYEES yang diisi dengan detail karyawan yang baru dipekerjakan selama kuartal pertama setiap tahun. Staf administrasi menambahkan setiap detail karyawan dengan savepoint, untuk mengembalikan data yang salah kapan saja selama aktivitas pemberian data. Perhatikan bahwa dia menyimpan nama savepoint sama dengan nama karyawan.

INSERT INTO employees (employee_id, first_name, hire_date, job_id, salary, department_id)
VALUES (105, 'Allen',TO_DATE ('15-JAN-2013','SALES',10000,10);

SAVEPOINT Allen;

INSERT INTO employees (employee_id, first_name, hire_date, job_id, salary, department_id)
VALUES (106, 'Kate',TO_DATE ('15-JAN-2013','PROD',10000,20);

SAVEPOINT Kate;

INSERT INTO employees (employee_id, first_name, hire_date, job_id, salary, department_id)
VALUES (107, 'McMan',TO_DATE ('15-JAN-2013','ADMIN',12000,30);

SAVEPOINT McMan;

Misalkan, operator data feeding menyadari bahwa dia salah memasukkan gaji 'Kate' dan 'McMan'. Dia mengembalikan transaksi aktif ke savepoint Kate dan memasukkan kembali detail karyawan untuk Kate dan McMan.

ROLLBACK TO SAVEPOINT Kate;

INSERT INTO employees (employee_id, first_name, hire_date, job_id, salary, department_id)
VALUES (106, 'Kate',TO_DATE ('15-JAN-2013','PROD',12500,20);

SAVEPOINT Kate;

INSERT INTO employees (employee_id, first_name, hire_date, job_id, salary, department_id)
VALUES (107, 'McMan',TO_DATE ('15-JAN-2013','ADMIN',13200,30);

SAVEPOINT McMan;

Setelah dia selesai dengan entri data, dia dapat melakukan seluruh transaksi dengan menerbitkan COMMIT di sesi saat ini.

Baca Konsistensi

Oracle menjaga konsistensi di antara pengguna di setiap sesi dalam hal akses data dan tindakan baca / tulis.

Ketika DML terjadi pada tabel, nilai data asli yang diubah oleh tindakan dicatat dalam catatan pembatalan database. Selama transaksi tidak dimasukkan ke dalam database, setiap pengguna di sesi lain yang menanyakan data yang diubah akan melihat nilai data asli. Oracle menggunakan informasi saat ini di area global sistem dan informasi dalam catatan undo untuk membuat tampilan data tabel yang konsisten baca untuk kueri. Hanya ketika transaksi dilakukan, perubahan transaksi menjadi permanen. Transaksi adalah kunci strategi Oracle untuk menyediakan konsistensi baca.

Titik awal untuk tampilan yang konsisten-baca dihasilkan atas nama pembaca

Kontrol ketika data yang dimodifikasi dapat dilihat oleh transaksi lain dari database untuk membaca atau memperbarui