Menggunakan Pertanyaan Operator Set
1.Which SET operator does the following figure indicate?
- UNION
- UNI SEMUA
- INTERSECT
- MINUS
Answer: A. Operator set digunakan untuk menggabungkan hasil dari dua (atau lebih) pernyataan SELECT. Operator set yang valid di Oracle 11g adalah UNION, UNION ALL, INTERSECT, dan MINUS. Saat digunakan dengan dua pernyataan SELECT, operator kumpulan UNION mengembalikan hasil dari kedua kueri.Namun, jika ada duplikat, mereka dihapus, dan rekaman duplikat dicantumkan hanya sekali.Untuk menyertakan duplikat dalam hasil, gunakan UNION ALL set operator.INTERSECT hanya mencantumkan catatan yang dikembalikan oleh kedua kueri; operator himpunan MINUS menghapus hasil kueri kedua dari keluaran jika hasil tersebut juga ditemukan di hasil kueri pertama. Operasi set INTERSECT dan MINUS menghasilkan hasil yang tidak digandakan.
2.Which SET operator does the following figure indicate?
- UNION
- UNI SEMUA
- INTERSECT
- MINUS
Answer: B. UNION ALL Mengembalikan baris gabungan dari dua query tanpa mengurutkan atau menghapus duplikat.
3.Which SET operator does the following figure indicate?
- UNION
- UNI SEMUA
- INTERSECT
- MINUS
Answer: C. INTERSECT Hanya mengembalikan baris yang muncul di set hasil kedua kueri, mengurutkan dan menghapus duplikat.
4.Which SET operator does the following figure indicate?
- UNION
- UNI SEMUA
- INTERSECT
- MINUS
Answer: D. MINUS Hanya mengembalikan baris di set hasil pertama yang tidak muncul di set hasil kedua, menyortirnya dan menghapus duplikat.
5.What is true about SET operators?
- Mereka mengubah nilai baris
- Mereka menggabungkan hasil dari dua kueri komponen menjadi satu hasil
- Mereka menggabungkan hasil dari 10 kueri komponen menjadi dua kumpulan hasil.
- Mereka menggabungkan hasil dari dua atau lebih kueri komponen menjadi satu hasil
Answer: D. Operator set digunakan untuk menggabungkan hasil dari dua (atau lebih) pernyataan SELECT. Operator set yang valid di Oracle 11g adalah UNION, UNION ALL, INTERSECT, dan MINUS.
6.What are the queries containing SET operators called?
- Sub-queries
- Sub-kueri terkait
- GROUP BY queries
- Kueri gabungan
Answer: D.
7.What is true about the UNION operator?
- Ini mengembalikan baris dari kueri gabungan bersama dengan nilai NULL
- Ini mengembalikan baris untuk kueri gabungan setelah menghilangkan duplikat
- Ini mengembalikan baris untuk kueri gabungan bersama dengan nilai duplikat
- Ini mengembalikan baris untuk kueri gabungan yang mengabaikan nilai NULL
Answer: B. UNION Mengembalikan baris gabungan dari dua kueri, menyortirnya dan menghapus duplikat.
8.What is true about the UNION ALL operator?
- Ini mengembalikan baris dari kueri gabungan bersama dengan nilai NULL
- Ini mengembalikan baris untuk kueri gabungan setelah menghilangkan duplikat
- Ini mengembalikan baris untuk kueri gabungan bersama dengan nilai duplikat
- Ini mengembalikan baris untuk kueri gabungan yang mengabaikan nilai NULL
Answer: C. UNION ALL Mengembalikan baris gabungan dari dua query tanpa mengurutkan atau menghapus duplikat.
9.What is true about the INTERSECT operator?
- Ini mengembalikan baris dari kueri gabungan bersama dengan nilai NULL
- Ini mengembalikan baris untuk kueri gabungan setelah menghilangkan duplikat
- Ini mengembalikan baris umum dari kueri gabungan
- Bukan dari salah satu di atas
Answer: C. INTERSECT Hanya mengembalikan baris yang muncul di set hasil kedua kueri, mengurutkan dan menghapus duplikat.
10.What is true about the MINUS operator?
- Ini mengembalikan baris dari kueri pertama tetapi tidak dari kueri kedua
- Ini mengembalikan baris untuk kueri kedua tetapi tidak dari kueri pertama
- Ini mengembalikan baris duplikat untuk kueri gabungan
- Ini mengembalikan baris untuk kueri gabungan yang mengabaikan nilai NULL
Answer: A. MINUS Hanya mengembalikan baris di set hasil pertama yang tidak muncul di set hasil kedua, menyortirnya dan menghapus duplikat.
11.What is the precedence of the set operators UNION, UNION ALL, INTERSECT and MINUS?
- UNION, UNION ALL, INTERSECT dan MINUS
- MINUS, UNION, UNION ALL dan INTERSECT
- INTERSECT, MINUS, UNION ALL, UNION
- Prioritas yang sama
Answer: D. Operator SET memiliki prioritas yang sama.
12.What is the order of evaluation of set operators?
- Kiri ke kanan
- Kanan ke kiri
- Evaluasi Acak
- Atas ke bawah
Answer: A, D. Dengan asumsi bahwa tidak ada pengelompokan query menggunakan tanda kurung, operator SET akan dievaluasi dari atas ke bawah dan kiri ke kanan secara horizontal.
13.In which of the following cases, parenthesis should be specified?
- Saat INTERSECT digunakan dengan operator set lainnya
- Saat UNION digunakan dengan UNION ALL
- Saat MINUS digunakan untuk kueri
- Bukan dari salah satu di atas
Answer: A. Penggunaan tanda kurung secara eksplisit akan mengubah urutan evaluasi saat INTERSECT digunakan dengan operator lain.
14.What is true about the SELECT clause when SET operators are used?
- Tidak ada batasan pada kolom yang dipilih
- Kolom, ekspresi yang digunakan dalam klausa SELECT harus sesuai dengan angka dalam kueri gabungan
- Kolom, ekspresi yang digunakan dalam klausa SELECT harus N di kueri pertama dan N-1 di kueri gabungan berikutnya
- Baik B dan C
Answer: B. Semua gabungan harus memiliki no yang sama. kolom saat menggunakan operator SET. Kolom terkait dalam kueri yang menyusun kueri gabungan harus dari grup tipe data yang sama.
15.What is true about the SET operators?
- Klausa SELECT harus memiliki jumlah kolom yang sama, tipe datanya bisa berbeda
- Operator SET hanya dapat digunakan untuk menggabungkan dua query
- Tipe data dari setiap kolom di kueri kedua harus cocok dengan tipe data dari kolom yang sesuai di kueri pertama.
- Bukan dari salah satu di atas
Answer: C. Semua gabungan harus memiliki no yang sama. kolom saat menggunakan operator SET. Kolom terkait dalam kueri yang menyusun kueri gabungan harus dari grup tipe data yang sama.
16.Where can the ORDER BY clause be used in case when SET operators are used?
- Di setiap kueri yang digabungkan
- Hanya di kueri pertama
- Di bagian paling akhir kueri gabungan
- Bukan dari salah satu di atas
Answer: C. Jika klausa ORDER BY digunakan di antara kueri apa pun yang digabungkan menggunakan operator SET, ini akan memunculkan kesalahan ORA.
17.What is true about the queries that have SET operators in their WHERE clause?
- Kueri ini harus memiliki no yang sama. dan tipe data kolom dalam klausa SELECT mereka.
- Tidak. kolom yang digunakan dalam kueri klausa WHERE dan SELECT utama bisa berbeda
- Tidak. kolom yang digunakan dalam klausa WHERE harus sama, tipe datanya bisa berbeda
- Bukan dari salah satu di atas
Answer: A. Semua gabungan harus memiliki no yang sama. kolom saat menggunakan operator SET. Kolom terkait dalam kueri yang menyusun kueri gabungan harus dari grup tipe data yang sama.
18.What is true about the columns in the second query with respect to the columns in the first query?
- Kolom di kueri ke-2 harus berada dalam grup tipe data yang sama dengan kolom yang sesuai di kueri pertama
- Jika kolom dalam kueri pertama adalah NOMOR, kolom terkait dalam kueri kedua harus berupa VARCHAR2
- Jika kolom di kueri pertama adalah NOMOR, kolom yang sesuai di kueri kedua juga harus NOMOR.
- Bukan dari salah satu di atas
Answer: A, C.
19.What among the following is true about SET operators?
- Operator SET tidak dapat digunakan dalam sub-query
- Operator SET hanya dapat digunakan di klausa WHERE
- ORDER BY dapat digunakan untuk semua kueri yang digabungkan oleh operator SET
- Operator SET dapat digunakan dalam sub-query
Answer: D.
20.What is the best way to change the precedence of SET operators given the fact that they have equal precedence?
- Urutan penggunaan operator SET dapat diubah untuk mengubah prioritas
- Prioritas yang sama tidak dapat diubah
- Tanda kurung dapat digunakan untuk mengubah prioritas
- Bukan dari salah satu di atas
Answer: C. Tanda kurung dapat digunakan untuk mengelompokkan kueri tertentu untuk mengubah prioritas secara eksplisit. Tanda kurung lebih disukai daripada operator SET lainnya selama eksekusi.
21.What can be said about duplicate values and SET operators?
- Tidak ada operator SET yang menampilkan nilai duplikat
- Semua operator SET dapat menampilkan nilai duplikat
- Hanya operator UNION ALL yang menampilkan nilai duplikat
- Bukan dari salah satu di atas
Answer: C. UNION, INTERSECT, dan MINUS secara otomatis menghilangkan nilai duplikat
Examine the structure of the EMPLOYEES and DEPARTMENTS tables and consider the following query and answer the questions 22 and 23.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SELECT department_id
FROM employees e
UNION
SELECT department_id
FROM departments
22.What will be displayed in the result of this query?
- Ini akan menampilkan id departemen berbeda yang terdapat bersama dalam tabel KARYAWAN dan DEPARTEMEN
- Ini akan membuang kesalahan ORA
- Tidak ada baris yang dipilih
- Bukan dari salah satu di atas
Answer: A. UNION Mengembalikan baris gabungan dari dua kueri, menyortirnya dan menghapus duplikat.
23.What is true about the query given above?
- Kueri ini mengembalikan kesalahan ORA
- Itu berhasil dijalankan tetapi tidak memberikan hasil
- Query dari tabel yang berbeda tidak dapat digunakan dengan operator SET
- Kueri berhasil dijalankan dan memberikan hasil seperti yang diharapkan
Answer: D. Kueri gabungan adalah satu kueri yang terdiri dari beberapa kueri menggunakan tabel berbeda.
24.What is the default sorting order of the results when UNION ALL operator is used?
- Descending
- Ascending
- Baik A atau B
- Semua yang di atas
Answer: B. Kueri gabungan akan secara default mengembalikan baris yang diurutkan di semua kolom, dari kiri ke kanan dalam urutan menaik. Satu-satunya pengecualian adalah UNION ALL, di mana baris tidak akan diurutkan. Satu-satunya tempat di mana klausa ORDER BY diizinkan adalah di akhir kueri gabungan.
25.What will be the output of the compound query in which columns in the SELECT are of CHAR and equal length?
- Output akan memiliki tipe data VARCHAR2 dengan panjang yang sama
- Output akan memiliki tipe data CHAR dengan panjang yang sama
- Output akan memiliki tipe data CHAR dengan panjang yang berbeda
- Outputnya akan memiliki tipe data NOMOR dengan panjang yang sama
Answer: B. Kolom dalam kueri yang membentuk kueri gabungan bisa memiliki nama yang berbeda, tetapi kumpulan hasil keluaran akan menggunakan nama kolom di kueri pertama. Kolom terkait dalam kueri yang menyusun kueri gabungan harus dari grup tipe data yang sama.
26.What will be the output of the compound query in which columns in the SELECT are of CHAR and different lengths?
- Output akan memiliki tipe data VARCHAR2 dengan panjang yang sama
- Output akan memiliki tipe data CHAR dengan panjang yang sama
- Output akan memiliki tipe data CHAR dengan panjang yang berbeda
- Outputnya akan memiliki tipe data VARCHAR2 dengan panjang nilai CHAR yang lebih besar
Answer: D. Meskipun daftar kolom yang dipilih tidak harus tipe data yang persis sama, daftar tersebut harus dari grup tipe data yang sama. Kumpulan hasil dari kueri gabungan akan memiliki kolom dengan tingkat presisi yang lebih tinggi.
27.What will be the output of a compound query if either or both queries select values of VARCHAR2?
- Outputnya akan memiliki tipe data VARCHAR2.
- Output akan memiliki tipe data CHAR dengan panjang yang sama
- Output akan memiliki tipe data CHAR dengan panjang yang berbeda
- Outputnya akan memiliki tipe data VARCHAR2 dengan panjang nilai CHAR yang lebih besar
Answer: A. Meskipun daftar kolom yang dipilih tidak harus tipe data yang persis sama, daftar tersebut harus dari grup tipe data yang sama. Kumpulan hasil dari kueri gabungan akan memiliki kolom dengan tingkat presisi yang lebih tinggi.
28.What is true if the compound queries select numeric data?
- Akan ada prioritas yang sama dari nilai numerik, operator
- Nilai yang dikembalikan akan ditentukan oleh prioritas numerik
- Nilai kembali akan menjadi tipe data NUMBER
- Bukan dari salah satu di atas
Answer: B, C. Meskipun daftar kolom yang dipilih tidak harus tipe data yang persis sama, daftar tersebut harus dari grup tipe data yang sama. Kumpulan hasil dari kueri gabungan akan memiliki kolom dengan tingkat presisi yang lebih tinggi.
29.What will happen if the SELECT list of the compound queries returns both a VARCHAR2 and a NUMBER data type result?
- Oracle akan mengubahnya secara implisit dan mengembalikan hasil tipe data VARCHAR2
- Oracle akan mengubahnya secara implisit dan mengembalikan hasil tipe data NOMOR
- Kesalahan ORA muncul
- Bukan dari salah satu di atas
Answer: C. Oracle tidak mengubah tipe data secara implisit.
30.What is true about the UNION operator?
- Ini menghilangkan nilai duplikat yang mengabaikan nilai NULL
- Ini mengembalikan nilai duplikat mengabaikan nilai NULL
- Ini mengembalikan nilai duplikat termasuk nilai NULL
- Ini menghilangkan nilai duplikat dan tidak mengabaikan nilai NULL
Answer: D. Nilai NULL tidak diabaikan ketika operator UNION digunakan
31.What can be said about the names and columns of a SQL query which uses the UNION operator?
- Nama-nama kolom harus identik
- Nama dan tipe data kolom harus identik
- Nama kolom tidak harus sama persis
- Bukan dari salah satu di atas
Answer: C. Kolom dalam kueri yang membentuk kueri gabungan bisa memiliki nama yang berbeda, tetapi kumpulan hasil keluaran akan menggunakan nama kolom di kueri pertama.
Consider the following exhibit of the JOB_HISTORY table and the query that follows. Answer the questions 32 and 33 below the query.
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
SELECT employee_id , first_name, last_name, job_id
FROM employees E
UNION
SELECT employee_id , first_name, last_name, job_id
From job_history;
32.How many times the each employee will get displayed by the above query?
- 0
- 1
- 2
- 4
Answer: B. UNION Mengembalikan baris gabungan dari dua kueri, menyortirnya dan menghapus duplikat.
33.What will be the outcome of the above query?
- Ini menampilkan detail pekerjaan saat ini dan sebelumnya dari karyawan dua kali
- Ini menampilkan detail pekerjaan saat ini dan sebelumnya dari karyawan hanya sekali
- Baik A atau B
- Bukan dari salah satu di atas
Answer: B.
Examine the given table structures and consider the following query and answer the questions 34 to 37 that follow:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
SELECT employee_id , job_id, department_id
FROM employees
UNION
SELECT employee_id , job_id, department_id
From job_history;
34.Assuming that an employee with ID 121 has held 2 job IDs in his tenure in the company. Considering the above query, how many times will his records be displayed in the results?
- Once
- Twice
- Thrice
- Bukan dari salah satu di atas
Answer: B. UNION Mengembalikan baris gabungan dari dua kueri, menyortirnya dan menghapus duplikat. Duplikat diukur dengan kombinasi kolom dan bukan kolom individual secara terpisah.
35.Assuming that the employee with ID 121 held two positions in two different departments - 10 and 20 in the company.He worked as 'SA_REP' in both the departments 10 and 20. What will be the outcome of the above query ?
- 2 baris
- 3 baris
- Tidak ada baris
- Kesalahan ORA
Answer: B.
36.Which statements best describes the inference drawn from the questions 34 and 35?
- Ada nilai duplikat untuk kode pekerjaan
- Kueri dijalankan tetapi hasil yang dihasilkan tidak terduga
- Tidak ada nilai duplikat untuk departemen
- Bukan dari salah satu di atas
Answer: C. Karena kombinasi kode pekerjaan dan departemen itu unik, tidak ada duplikat yang diperoleh.
37.What will be the sorting in the result set obtained by the query?
- Turun pada ID Karyawan
- Turun di Job ID
- Naik ke ID Karyawan
- Naik ke ID Departemen
Answer: C. Pengurutan default akan menaik berdasarkan kolom pertama yaitu: ID Karyawan dalam kasus ini. Namun, perilaku ini dapat diubah dengan menempatkan klausa ORDER BY tunggal di akhir.
38.Which of the following operators will be used to obtain duplicate records from the component queries?
- UNION
- UNI SEMUA
- MINUS
- Bukan dari salah satu di atas
Answer: B. UNION ALL tidak menghilangkan nilai duplikat.
39.What is the difference between the UNION and the UNION ALL operators?
- Tidak ada perbedaan
- UNION ALL juga menampilkan nilai duplikat
- Output dalam kasus UNION ALL tidak diurutkan secara default
- Bukan dari salah satu di atas
Answer: B, C. Saat digunakan dengan dua pernyataan SELECT, operator set UNION mengembalikan hasil dari kedua kueri. Namun, jika ada duplikat, mereka akan dihapus, dan rekaman duplikat hanya dicantumkan sekali. Untuk menyertakan duplikat dalam hasil, gunakan operator set UNION ALL
40.What is true about the INTERSECT operator?
- Jumlah kolom dan tipe data kolom di kueri komponen harus sama
- Nama-nama kolom dan tipe data dari kolom-kolom di kueri komponen harus sama
- Baik A dan B
- Bukan dari salah satu di atas
Answer: A. Ini adalah fitur kriteria properti umum operator SET.
41.What can be said about the result set if the order of the intersected tables is altered when using INTERSECT?
- Hasilnya diubah
- Hasilnya tetap sama
- Penyortiran berubah pada perubahan
- Bukan dari salah satu di atas
Answer: B.
42.What among the following is true about the INTERSECT operator?
- Ini mengabaikan nilai NULL
- Itu tidak mengabaikan nilai NULL
- Ini mengembalikan semua baris dari kueri komponen pertama
- Bukan dari salah satu di atas
Answer: B.
Answer the related questions 43 and 44 given below.
43.You need to display the names and job IDs of those employees who currently have a job title that is the same as their previous one. Which of the following queries will work? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
SELECT employee_id , job_id, first_name, last_name FROM employees UNION SELECT employee_id , job_id, first_name, last_name FROM job_history;
SELECT employee_id , job_id, first_name, last_name FROM employees INTERSECT SELECT employee_id , job_id, first_name, last_name FROM job_history;
SELECT employee_id , job_id, first_name, last_name FROM employees UNION ALL SELECT employee_id , job_id, first_name, last_name FROM job_history;
- Bukan dari salah satu di atas
Answer: B.
44.Considering the above query i.e. Option B in question 43, what will be the result if the department ID is also included in the SELECT clause?
- Hasilnya akan sama
- Hasilnya akan berbeda
- Hasilnya akan sama tetapi urutannya akan berbeda
- Bukan dari salah satu di atas
Answer: A. Hasilnya dapat diartikan sebagai - karyawan yang pernah bekerja dengan jabatan yang sama di departemen yang sama.
45.What is true about the MINUS operator?
- Ini mengembalikan semua baris dari semua kueri komponen
- Ini hanya mengembalikan baris umum dari semua kueri komponen
- Ini mengembalikan semua baris dari kueri pertama dan bukan dari kueri berikutnya
- Ini mengembalikan semua baris berbeda yang dipilih oleh kueri pertama, tetapi tidak ada dalam kueri berikutnya
Answer: D. Operator set MINUS menghapus hasil kueri kedua dari keluaran jika hasil tersebut juga ditemukan di hasil kueri pertama
46.What can be said regarding the number of columns and data types of the component queries when a MINUS operator is used?
- Mereka harus sama, tipe datanya mungkin berbeda tetapi mereka harus termasuk dalam grup tipe data yang sama.
- Mereka harus sama dengan nama kolomnya
- Baik A dan B
- Bukan dari salah satu di atas
Answer: A. Fitur umum operator SET.
47.You need to display the employee IDs of the employees who have not changed their jobs even once during tenure in the company. Which of the following queries will be correct in this case? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
SELECT employee_id FROM employees UNION SELECT employee_id FROM job_history;
SELECT employee_id FROM employees INTERSECT Select employee_id FROM job_history;
SELECT employee_id FROM employees MINUS Select employee_id FROM job_history;
SELECT employee_id FROM employees UNION ALL SELECT employee_id FROM job_history;
Answer: C.
Examine the given table structures and consider the following query answer the questions 48 and 49 that follow:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
SELECT employee_id , first_name, job_id
FROM employees
UNION
SELECT employee_id , NULL "first_name", job_id
FROM job_history;
48.What is true about the above query?
- Ini melempar kesalahan karena TO_CHAR (NULL) tidak dapat digunakan
- Ini berhasil dijalankan dan memberikan nilai untuk id karyawan, first_name dan peran pekerjaan saat ini termasuk baris duplikat
- Ini berhasil dijalankan dan memberikan nilai untuk karyawan, nama_pertama dan semua pekerjaan yang dipegang oleh karyawan tidak termasuk baris duplikat
- Bukan dari salah satu di atas
Answer: C. Setiap kueri harus berisi jumlah kolom yang sama, yang dibandingkan secara posisional. NULL dapat diganti sebagai pengganti kolom yang hilang di kueri lain dalam kueri gabungan yang sama.
49.Considering the above query, if the UNION operator is replaced by the MINUS operator, what will the result mean?
- Hasilnya menunjukkan karyawan yang memiliki entri di tabel JOB_HISTORY
- Hasilnya menunjukkan karyawan yang tidak memiliki entri di JOB_HISTORY, tetapi mereka ada di tabel EMPLOYEES
- Salah satu dari A atau B
- Bukan dari salah satu di atas
Answer: B. MINUS memberikan hasil unik yang ada di kueri pertama tetapi tidak di kueri kedua.
Consider the exhibit given below and answer the questions 50 and 51 that follow:
50.What will be the outcome of the following query?
SELECT AU_DETAILS
FROM AUDIT
UNION
SELECT AU_DETAILS
FROM AUDIT_YEARLY;
- Ini dijalankan dengan sukses memberikan hasil yang benar termasuk nilai duplikat
- Ini dijalankan dengan sukses memberikan hasil yang benar tidak termasuk nilai duplikat
- Ini melempar kesalahan ORA
- Bukan dari salah satu di atas
Answer: C. Kolom CLOB atau LONG tidak boleh berada di klausa SELECT saat menggunakan operator set UNION.
51.What will be the outcome of the query if UNION is replaced with UNION ALL?
- Ini akan mengeksekusi dengan sukses memberikan hasil yang benar termasuk nilai duplikat
- Ini melempar kesalahan ORA
- Ini akan dieksekusi dengan sukses memberikan hasil yang benar tidak termasuk nilai duplikat
- Itu berhasil dijalankan tetapi memberikan hasil yang salah.
Answer: B. Operator .UNION, UNION ALL, INTERSECT, dan MINUS saat digunakan dengan kolom LONG atau CLOB akan menampilkan error.
52.Assume that there are 4 component queries. How many SET operators can be used to combine them in a single compound query?
- 1
- 2
- 4
- 3
Answer: D. Operator SET yang akan digunakan adalah N-1 dimana N adalah banyaknya permintaan komponen.
53.What are SET operators called owning to the fact that two or more SELECTs are involved based on columns instead of rows when SET operators are used?
- Gabungan horizontal
- Cartesian Bergabung
- Gabungan vertikal
- Gabungan luar
Answer: C.
54.What is the difference between a UNION and INTERSECT operators? (Choose only the best difference)
- UNION menggabungkan hasil dari dua kueri komponen menjadi satu kumpulan hasil dengan nilai duplikat
- INTERSECT mengembalikan hanya baris-baris yang dikembalikan oleh masing-masing dari dua kueri komponen
- UNION memberikan nilai yang berbeda dari kueri komponen, INTERSECT memberikan nilai yang sama dari kueri komponen
- Baik B dan C
Answer: C.
Examine the structure of the EMPLOYEES table and consider the following query. Answer the questions 55 to 60 that follow.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
Query 1
SELECT *
FROM EMPLOYEES
where department_id = 10
Query 2
SELECT *
FROM EMPLOYEES E
where E.job_id IN (select first_name from EMPLOYEES E1 where E1.job_id = 'CLERK' and E.job_id = E1.job_id )
55.You need to extract a report where the results from both the queries are displayed. Which of the following operators should be used to get the required results?
- UNION
- UNI SEMUA
- INTERSECT
- Bukan dari salah satu di atas
Answer: B. UNION ALL Mengembalikan baris gabungan dari dua query tanpa mengurutkan atau menghapus duplikat.
56.You need to display all the duplicate values along with all the values existing in the result set from both the queries. Which of the following SET operators you can use in the above given queries?
- INTERSECT
- UNION
- MINUS
- Bukan dari salah satu di atas
Answer: D. UNION ALL akan memberikan hasil yang tidak diurutkan dengan duplikat.
57.What is the difference between the result sets when using a UNION and a UNION ALL set operators?
- Hasil yang ditetapkan dari UNION ALL disaring termasuk nilai duplikat
- Kumpulan hasil dari UNION disaring dan diurutkan termasuk nilai duplikat
- Hasil yang ditetapkan dari UNION ALL tidak diurutkan dan memiliki nilai duplikat
- Kumpulan hasil dari UNION disaring dan diurutkan tanpa nilai duplikat
Answer: C, D.
58.The UNION operator has more overhead on the database than the UNION ALL. What is wrong in this statement?
- Pernyataan itu benar
- Operator UNION ALL memiliki lebih banyak overhead pada basis Data daripada operator UNION
- UNION harus menyortir dan menghilangkan duplikat yang menghasilkan overhead tambahan
- Bukan dari salah satu di atas
Answer: A, C. UNION harus melakukan lebih banyak tugas daripada UNION ALL karena UNION menyortir dan mendeduplikasi kumpulan hasil. Oleh karena itu, disarankan bahwa kecuali baris yang berbeda diperlukan, UNION ALL harus digunakan.
59.What will be the outcome if the two queries given above are combined using the INTERSECT operator?
- Ini hanya akan menampilkan karyawan yang merupakan Panitera di Departemen 10
- Ini akan menampilkan semua karyawan yang ada di departemen 10
- Ini akan menampilkan semua Clerks.
- Bukan dari salah satu di atas
Answer: A. INTERSECT mengembalikan rekaman yang ada dalam kueri 1 DAN kueri 2.
60.What among the following is the difference between the INTERSECT and the UNION operators?
- INTERSECT mengikuti logika Boolean 'AND', UNION mengikuti logika Boolean 'OR'
- UNION mengikuti logika Boolean 'ATAU', sedangkan INTERSECT mengikuti logika 'AND'
- Salah satu dari A atau B
- Bukan dari salah satu di atas
Answer: A.
61.In which of the following SET operators, changing the order of the component queries will change the result set?
- UNION
- UNI SEMUA
- MINUS
- INTERSECT
Answer: C. MINUS Hanya mengembalikan baris di set hasil pertama yang tidak muncul di set hasil kedua, menyortirnya dan menghapus duplikat.
Consider the following query and answer the questions 62 to 66 that follow:
SELECT 4 from dual
INTERSECT
SELECT 1 from dual;
62.What will be the outcome of the given query?
- Tidak ada baris
- 4
- 1
- NULL
Answer: A. Tidak ada baris yang akan dipilih karena operator INTERSECT tidak akan mendapatkan hasil yang sama dari kedua kueri - operator INTERSECT memberikan hasil umum yang ada dalam kueri 1 DAN kueri 2.
63.What will be the outcome of the query if the INTERSECT operator is replaced with MINUS operator?
- 3
- 4
- 0
- 1
Answer: B. MINUS memberikan hasil yang ada di kueri pertama dan tidak ada di kueri kedua.
64.What will be the outcome of the above query if the INTERSECT operator is replaced with the UNION operator?
- 1
4
- 4
1
- NULL
- 0
Answer: A. UNION akan menghasilkan baris berbeda dalam hasil yang ditetapkan dalam urutan menaik.
65.What will be the outcome of the above query if the INTERSECT operator is replaced with the UNION ALL operator?
- 4
1
- 0
- NULL
- 1
4
Answer: A. UNION ALL menampilkan hasil seperti yang diposisikan dalam kueri tanpa menyortirnya.
66.What will be the outcome if the above query is modified as below?
SELECT 1 from dual
UNION ALL
SELECT 4 from dual;
- 1
4
- 4
1
- NULL
- Bukan dari salah satu di atas
Answer: A.
Examine the JOB_HISTORY_ARCHIVE table structure. It is a backup table for the JOB_HISTORY table with no additional column. Assuming that both the table have dissimilar data, consider the query given below and answer the questions 67 to 70 that follow:
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
(SELECT * FROM job_history;
MINUS
SELECT * FROM job_history_archive)
UNION ALL
(SELECT * FROM job_history_archive
MINUS
SELECT * FROM job_history;);
67. What will be the outcome of the query given above? (Choose the best answer)
- Ini akan mengembalikan baris-baris yang berbeda di dua tabel
- Ini akan mengembalikan baris umum di dua tabel
- Ini akan mengembalikan semua baris dari dua tabel
- Bukan dari salah satu di atas
Answer: A.
68.What can concluded if the above given query yields rows only from JOB_HISTORY table?
- Ini menunjukkan bahwa JOB_HISTORY berisi dua baris yang berbeda dari tabel JOB_HISTORY_ARCHIVE
- Ini menunjukkan bahwa dua baris sama dalam tabel JOB_HISTORY dan JOB_HISTORY_ARCHIVE
- Ini menunjukkan bahwa JOB_HISTORY_ARCHIVE berisi dua baris yang berbeda dari tabel JOB_HISTORY
- Bukan dari salah satu di atas
Answer: A.
69.What can be said if the above query gives no results?
- Ini menunjukkan bahwa kedua tabel tersebut memiliki data yang sama
- Ini menunjukkan bahwa kueri komponen ditempatkan secara salah
- Ini menunjukkan bahwa operator SET salah digunakan dalam query gabungan
- Bukan dari salah satu di atas
Answer: A.
70.With respect to the query given above, if duplicate records exist in the two tables, which of the following modifications should be made to the above given query?
- COUNT(*)
- JUMLAH (*) dan GROUP BY employee_id
- COUNT (*) dan ORDER BY employee_id
- Bukan dari salah satu di atas
Answer: B. JUMLAH (*) dapat digunakan untuk melihat perbedaan antar tabel.
Consider the following query:
SELECT 1 NUM, 'employee' TEXT FROM dual
UNION
SELECT TO_CHAR(NULL) NUM, 'departments' TEXT FROM dual;
71.What will be the outcome of the query given above?
-
NUM TEXT ---------- ----------- 1 employee departments
-
NUM TEXT ---------- ----------- 1 employee NULL departments
- Kesalahan ORA
-
NUM TEXT ---------- ----------- departments 1 employee
Answer: C. Di sini numerik 1 dibandingkan dengan karakter NULL yang memunculkan kesalahan "ORA-01790: ekspresi harus memiliki tipe data yang sama sebagai ekspresi yang sesuai".
Consider the following query and answer the questions 72 and 73 that follow:
SELECT months_between (sysdate, to_date('21-MAY-2013','DD-MON-YYYY')) FROM dual
UNION
SELECT TO_date(NULL) NUM FROM dual;
72.What will be the outcome of the query given above? (Assume that the SYSDATE is 1st July, 2013)
- Itu berhasil dijalankan dengan hasil yang benar
- Itu berhasil dijalankan tetapi tanpa hasil
- Ini melempar kesalahan ORA
- Bukan dari salah satu di atas
Answer: C. NUMBER dan DATE tidak termasuk dalam tipe data yang sama gagal. Di sini angka yang diperoleh MONTHS_BETWEEN dibandingkan dengan DATE dan karenanya kesalahan.
73.Assume that the SELECT statement in the 2nd query is modified as below:
SELECT to_number (NULL) NUM FROM dual;
Apa hasilnya karena perubahan ini?
- Itu berhasil dijalankan dengan hasil yang benar
- Itu berhasil dijalankan tetapi tanpa hasil
- Ini melempar kesalahan ORA
- Bukan dari salah satu di atas
Answer: A.
74.Examine the table structures and consider the following query:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
SELECT employee_id "Employee ID"
FROM employees
UNION
SELECT employee_id "EMP ID"
FROM job_history;
Manakah dari judul kolom di bawah ini yang akan ditampilkan di set hasil?
- ID EMP
- identitas pegawai
- EMPLOYEE_ID
- Kesalahan ORA karena nama kolom harus sama di kueri komponen.
Answer: B. Kolom dalam kueri yang membentuk kueri gabungan bisa memiliki nama yang berbeda, tetapi kumpulan hasil keluaran akan menggunakan nama kolom di kueri pertama.
Examine the two table structures given and consider the following query and answer the questions 75 and 76 that follow:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
SELECT employee_id
FROM employees e
UNION
SELECT employee_id
FROM job_history j
ORDER BY j.employee_id ;
75.What will be the outcome of the query given above?
- Hasilnya akan diurutkan berdasarkan ID karyawan dari tabel JOB_HISTORY
- Hasilnya akan diurutkan berdasarkan ID karyawan dari tabel EMPLOYEES
- Tidak akan ada urutan hasil
- Kesalahan ORA
Answer: D. ORDER BY harus dilakukan berdasarkan nama kolom dari kueri pertama dan bukan dari kolom kueri ke-2.
76.Which of the following ORDER BY clauses can replace the erroneous ORDER BY in the query given above?
- ORDER OLEH e.employee_id
- ORDER BY j.2
- ORDER OLEH 1
- Tidak satu pun di atas, ORDER BY tidak diizinkan dalam kueri
Answer: C. Ini adalah spesifikasi yang lebih umum dan Oracle akan memesan berdasarkan kolom pertama dari kueri pertama.
77.Consider the following exhibit and answer the question below:
SELECT au_doc
From audit
UNION
SELECT au_doc
From audit_yearly;
Apa hasil dari kueri yang diberikan di atas?
- Ini memberikan dokumen Audit antara dua tabel
- Ini memberikan kesalahan ORA pada eksekusi
- Ini memberikan dokumen Audit dari tabel AUDIT
- Bukan dari salah satu di atas
Answer: B. Kolom LONG tidak dapat digunakan dengan operator SET.
78.Consider the query given below:
SELECT col_1
From TABLE (package1.proc1)
UNION
SELECT col_1
From TABLE (package2.proc2);
Apa hasil dari kueri yang diberikan di atas?
- Itu berhasil dijalankan dengan duplikat
- Itu berhasil dijalankan tanpa duplikat
- Ini melempar kesalahan ORA
- Bukan dari salah satu di atas
Answer: C. Ekspresi TABLE tidak dapat digunakan dengan operator SET.
Examine the two table structures given and consider the following query. Answer the questions 79 and 80 that follow:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
SELECT employee_id , job_id
FROM employees E
UNION
SELECT employee_id , job_id
FROM job_history J
FOR UPDATE OF job_id;
79.What happens when the query is executed?
- Kesalahan ORA
- Employee_id and job_id
- Employee_id
- Bukan dari salah satu di atas
Answer: A. Klausa FOR UPDATE tidak dapat digunakan dengan kueri yang digabungkan menggunakan operator SET.
80.What will be the outcome of the following query?
SELECT * from employees
UNION
SELECT job_id FROM job_history;;
- Ini akan memberikan semua kolom dari tabel karyawan dan hanya kolom job_id dari tabel job_history
- Ini akan memunculkan kesalahan karena jumlah kolom harus cocok dalam kueri komponen
- Baik B atau C
- Bukan dari salah satu di atas
Answer: B.
81.If UNION, UNION ALL, INTERSECT are used in one SQL statement which of the following is true regarding the SQL statement?
- UNION, UNION ALL akan dieksekusi terlebih dahulu dan kemudian set hasil akan digunakan untuk pernyataan INTERSECT.
- Eksekusi INTERSECT akan mendahului eksekusi UNION dan UNION ALL.
- Eksekusi akan dilakukan dari kanan ke kiri dengan mempertimbangkan semua operator pada saat bersamaan.
- Eksekusi akan dilakukan dari kiri ke kanan dengan mempertimbangkan semua operator pada saat bersamaan.
Answer: D.
82.Consider the query given below and answer the question that follow:
SELECT '3' FROM dual
INTERSECT
SELECT 3f FROM dual;
Apa yang benar terkait eksekusi kueri yang diberikan di atas?
- Itu berhasil dijalankan.
- Ini membuat kesalahan
- Ini memberikan hasil 3.
- Ini memberikan hasil 3f
Answer: B. Literal karakter harus diapit dalam tanda kutip tunggal.
83.Which of the following is false for set operators used in SQL queries?
- Operator set valid ketika digunakan pada kolom dengan tipe data LONG.
- Operator set tidak valid pada kolom tipe BLOB, CLOB, BFILE, VARRAY, atau tabel bersarang.
- Agar kueri pemilihan berisi ekspresi, alias kolom harus disediakan untuk merujuknya ke order_by_clause.
- Anda tidak dapat menggunakan operator ini dalam pernyataan SELECT yang berisi ekspresi koleksi TABLE.
Answer: A. Operator SET tidak didukung untuk tipe data LONG, CLOB dan BLOB.
84.Examine the given table structure and evaluate the following SQL statement:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT employee_id , last_name "Last Name"
FROM employees
WHERE department_id = 100
UNION
SELECT employee_id EMPLOYEE_NO, last_name
FROM employees
WHERE department_id = 101;
Klausa ORDER BY mana yang valid untuk kueri di atas? (Pilih semua yang sesuai.)
- ORDER OLEH 2,1
- PESAN OLEH EMPLOYEE_NO
- ORDER OLEH 2, employee_id
- ORDER OLEH "EMPLOYEE_NO"
Answer: A, C. Klausa ORDER BY harus mereferensikan kolom dengan posisinya atau nama yang dirujuk oleh kueri pertama.
85.Which of the following clauses would you use to exclude the column from the 2nd query out of the two queries combined using SET operators?
- GRUP OLEH
- DIPESAN OLEH
- MINUS
- UNION
Answer: C.
86.Examine the given table structure as given. What will be the outcome of the below query?
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT distinct department_id
FROM employees
WHERE salary > ANY (SELECT AVG (salary)
FROM employees
GROUP BY department_id )
UNION
SELECT *
FROM employees
WHERE salary > ANY (SELECT MAX (salary)
FROM employees
GROUP BY department_id );
- Ini akan menampilkan semua ID departemen yang memiliki gaji rata-rata dan gaji maksimum
- Ini akan melempar kesalahan ORA sebagai tidak. kolom yang dipilih di kedua kueri berbeda
- Ini akan menampilkan semua ID departemen yang memiliki gaji rata-rata
- Ini akan menampilkan semua ID departemen yang memiliki gaji maksimum
Answer: B. Tidak. kolom harus sama.
87.What among the following is true about the UNION operator?
- UNION beroperasi hanya pada kolom pertama dalam daftar SELECT
- UNION beroperasi pada kolom pertama dari daftar SELECT di kueri komponen
- UNION beroperasi di semua kolom yang dipilih.
- Bukan dari salah satu di atas
Answer: C. UNION beroperasi di semua kolom dalam daftar SELECT dan tidak mengabaikan kolom apa pun.
88.You need to display the departments where the employees with the JOB IDs 'SA_REP' or 'ACCOUNTANT' work. Which of the following queries will fetch you the required results? (Consider the given table structure)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT department_id FROM employees E Where job_id = 'SA_RE' UNION SELECT department_id FROM employees E Where job_id = 'ACCOUNTANT';
SELECT department_id FROM employees E Where job_id = 'SA_REP' UNION ALL Select department_id FROM employees E Where job_id = 'ACCOUNTANT';
SELECT department_id FROM employees E Where job_id = 'SA_REP' INTERSECT Select department_id FROM employees E Where job_id = 'ACCOUNTANT';
SELECT department_id FROM employees E Where job_id = 'SA_REP' MINUS Select department_id FROM employees E Where job_id = 'ACCOUNTANT';
Answer: A.
89.Which of the following statement is true about the ordering of rows in a query which uses SET operator?
- Tidak mungkin menggunakan ORDER BY dalam kueri individual yang membuat kueri gabungan.
- Klausa ORDER BY dapat ditambahkan ke akhir kueri gabungan.
- Baris yang dikembalikan oleh UNION ALL akan berada dalam urutan kemunculannya di dua kueri sumber.
- Baris yang dikembalikan oleh UNION akan disortir di semua kolomnya, dari kanan ke kiri.
Answer: A, B, C.
90.The UNION operator was used to fulfill which of the following function before the ANSI SQL syntax in place?
- KANAN OUTER GABUNG
- LEFT OUTER GABUNG
- EQUI-JOIN
- FULL OUTER JOIN
Answer: D.
Answer the related questions 91 and 92 given below. Consider the table structures as given here:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
91.You need to find the job IDs which do not have any JOB history logged for them. Which of the following queries will work? (Consider the given table structures)
SELECT job_id FROM employees UNION ALL SELECT job_id FROM job_history;;
SELECT job_id FROM employees MINUS Select job_id FROM job_history;;
SELECT job_id FROM employees UNION SELECT job_id FROM job_history;;
- Bukan dari salah satu di atas
Answer: B.
92.Consider the following query:
SELECT distinct job_id
FROM employees
NATURAL JOIN job_history ;
Manakah dari kueri berikut ini yang identik dengan kueri di atas?
SELECT job_id FROM employees UNION SELECT job_id FROM job_history;;
SELECT job_id FROM employees UNION ALL SELECT job_id FROM job_history;;
SELECT job_id FROM employees MINUS Select job_id FROM job_history;;
SELECT job_id FROM employees INTERSECT SELECT job_id FROM job_history;;
Answer: A.
Examine the table structures given here. Consider the query given below and answer the related questions 93 to 97 that follow:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
SELECT job_id
FROM employees
UNION ALL
SELECT job_id
FROM job_history;;
93.If the EMPLOYEES table contains 5 records and the JOB_HISTORY contains 3 records, how many records will be obtained from the below query?
- 4
- 3
- 0
- 8
Answer: D. UNION ALL Mengembalikan baris gabungan dari dua query tanpa mengurutkan atau menghapus duplikat.
94.If the UNION ALL operator is replaced with UNION operator, how many records will be obtained? (Assume there are 6 distinct values in both the tables)
- 5
- 3
- 2
- 6
Answer: D. UNION Mengembalikan baris gabungan dari dua kueri, menyortirnya dan menghapus duplikat.
95.If the UNION ALL operator is replaced with MINUS operator, how many records will be obtained? (Assume there are 3 distinct values in EMPLOYEES and 2 in JOB_HISTORY)
- 3
- 2
- 1
- 0
Answer: C. MINUS Hanya mengembalikan baris di set hasil pertama yang tidak muncul di set hasil kedua, menyortirnya dan menghapus duplikat.
96.If the UNION ALL operator is replaced with INTERSECT operator, how many records will be obtained? (Assume there are 3 values common between the two tables)
- 8
- 6
- 3
- 2
Answer: C. INTERSECT Hanya mengembalikan baris yang muncul di set hasil kedua kueri, mengurutkan dan menghapus duplikat.
97.Consider the following query:
1.select job_id
2. from employees
3.ORDER BY department_id
4.UNION ALL
5.select job_id
6.FROM job_history;
7.ORDER BY department_id ;
Kueri di atas menghasilkan kesalahan. Baris mana dalam kueri di atas yang menghasilkan kesalahan?
- 3
- 7
- 2
- Tidak ada kesalahan yang diperoleh
Answer: A. ORDER BY seharusnya hanya muncul di akhir kueri gabungan dan bukan di kueri komponen.
98.Which of the following SET operator features are supported in SQL/Foundation:2003 but not by Oracle?
- UNI SEMUA
- MINUS SEMUA
- SEMUA PERSIMPANGAN
- KECUALI SEMUA
Answer: B, C, D.
99.You need to find out the common JOB IDs (excluding duplicates) in the departments 100 and 200. Which query will you fire to get the required results? (Consider the table structure as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT job_id from employee WHERE department_id = 100 INTERSECT SELECT job_id from employee WHERE department_id = 200;
SELECT job_id from employee WHERE department_id = 100 UNION ALL SELECT job_id from employee WHERE department_id = 200;
SELECT job_id from employee WHERE department_id = 100 MINUS Select job_id from employee WHERE department_id = 200;
SELECT job_id from employee WHERE department_id = 100 INTERSECT ALL Select job_id from employee WHERE department_id = 200;
Answer: A.
100.If a compound query contains both a MINUS and an INTERSECT operator, which will be applied first? (Choose the best answer.)
- INTERSECT, karena INTERSECT memiliki prioritas lebih tinggi daripada MINUS.
- MINUS, karena MINUS memiliki prioritas yang lebih tinggi daripada INTERSECT.
- Prioritas ditentukan oleh urutan penentuannya.
- Permintaan gabungan tidak dapat menyertakan MINUS dan INTERSECT.
Answer: C. Semua operator himpunan memiliki prioritas yang sama, sehingga prioritas ditentukan oleh urutan terjadinya.