Menggunakan Pertanyaan Fungsi Grup

1. Which of the following is NOT a GROUP BY function?

  1. MAX
  2. MIN
  3. NVL
  4. AVG

Answer: C. NVL adalah fungsi umum yang digunakan untuk memberikan nilai alternatif ke nilai NULL. Fungsi MAX, MIN dan AVG dapat digunakan sebagai fungsi GROUP BY.

2. Which of the following functions can be used without GROUP BY clause in SELECT query?

  1. COUNT
  2. MAX
  3. MIN
  4. AVG

Answer: A, B, C, D. Semua fungsi grup yang terdaftar bisa digunakan dalam kueri asalkan tidak ada kolom lain yang dipilih dalam kueri SELECT.

3. Which of the following SELECT query returns the department number with maximum salary compensated to an employee? (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)
  1. SELECT department_id , max(salary ) FROM employees ;
  2. SELECT department_id , max(salary ) FROM employees  GROUP BY department_id ;
  3. SELECT max(salary ) FROM employees  GROUP BY department_id ;
  4. SELECT max(salary ) FROM employees ;

Answer: B. Fungsi MAX dapat digunakan untuk mengembalikan gaji maksimum dalam suatu departemen di mana setiap kelompok dibentuk oleh suatu departemen.

4. Which of the following statements are true about the COUNT function?

  1. Fungsi COUNT menghitung jumlah baris
  2. Fungsi COUNT (*) menghitung jumlah baris dengan nilai duplikat dan NULL
  3. Fungsi COUNT (DISTINCT) menghitung jumlah baris yang berbeda
  4. COUNT (*) sama dengan COUNT (ALL)

Answer: B. COUNT (*) menghitung jumlah baris termasuk duplikat dan NULL. Gunakan DISTINCT dan SEMUA kata kunci untuk membatasi nilai duplikat dan NULL.

5. What are the appropriate data types accepted by GROUP BY functions?

  1. Tabel Bersarang
  2. NUMBER
  3. CLOB
  4. DATE

Answer: B. Tipe data untuk fungsi dengan argumen mungkin CHAR, VARCHAR2, NUMBER atau DATE.

6. A table T_COUNT has 12 number values as 1, 2, 3, 32, 1, 1, null, 24, 12, null, 32, null. Predict the output of the below query.

SELECT COUNT (*) FROM t_count;
  1. 12
  2. 6
  3. 9
  4. Melempar pengecualian karena fungsi COUNT tidak berfungsi dengan nilai NULL

Answer: A. COUNT (*) menghitung jumlah baris termasuk duplikat dan NULL. Gunakan DISTINCT dan SEMUA kata kunci untuk membatasi nilai duplikat dan NULL.

7. A table T_COUNT has 12 number values as 1, 2, 3, 32, 1, 1, null, 24, 12, null, 32, null. Predict the output of the below query.

SELECT COUNT (num) FROM t_count;
  1. 12
  2. 6
  3. 9
  4. Melempar pengecualian karena fungsi COUNT tidak berfungsi dengan nilai NULL

Answer: C. COUNT (kolom) mengabaikan nilai NULL tetapi menghitung duplikatnya.

8. A table T_COUNT has 12 number values as 1, 2, 3, 32, 1, 1, null, 24, 12, null, 32, null. Predict the output of the below query.

SELECT COUNT (ALL num) FROM t_count;
  1. 12
  2. 6
  3. 9
  4. Melempar pengecualian karena fungsi COUNT tidak berfungsi dengan nilai NULL

Answer: C. COUNT (kolom SEMUA) mengabaikan nilai NULL tetapi menghitung duplikatnya.

9. A table T_COUNT has 12 number values as 1, 2, 3, 32, 1, 1, null, 24, 12, null, 32, null. Predict the output of the below query.

SELECT COUNT (DISTINCT num) FROM t_count;
  1. 12
  2. 6
  3. 9
  4. Melempar pengecualian karena fungsi COUNT tidak berfungsi dengan nilai NULL

Answer: B. JUMLAH (kolom BERBEDA) menghitung perbedaan bukan nilai nol.

10. What happens when the below query is executed in SQL* Plus?

SELECT COUNT() FROM dual;
  1. Eksekusi berhasil dan tidak ada keluaran
  2. Eksekusi berhasil dan mengembalikan output sebagai '1'
  3. Melempar pengecualian "ORA-00909: jumlah argumen tidak valid"
  4. Melempar pengecualian "ORA-00904:" COUNT ": pengenal tidak valid" karena fungsi COUNT tidak berfungsi dengan tabel DUAL

Answer: C. Fungsi COUNT membutuhkan minimal satu argumen yang bisa berupa kolom dengan [ALL | DISTINCT] atau '*'.

11. Here are few statements about VARIANCE function in SQL.

saya. Fungsi ini menerima beberapa input numerik dan mengembalikan varians dari semua nilai

ii. Fungsi ini menerima kolom angka dan mengembalikan varians dari semua nilai kolom termasuk NULL

aku aku aku. Fungsi ini menerima kolom angka dan mengembalikan varians dari semua nilai kolom tidak termasuk NULL

Pilih kombinasi yang benar dari opsi di bawah ini.

  1. i dan iii
  2. i dan ii
  3. ii
  4. iii

Answer: C. Fungsi VARIANCE menerima argumen numerik tunggal sebagai nama kolom dan mengembalikan varians dari semua nilai kolom dengan mempertimbangkan NULL.

12. Which of the following is NOT a GROUP BY extensions in SQL?

  1. GRUP OLEH
  2. SET PENGELOMPOKAN
  3. CUBE
  4. ROLLUP

Answer: A. Operasi GROUPING SETS dapat digunakan untuk melakukan beberapa agregasi GROUP BY dengan satu query.

13. Select the correct statements about the below query. 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 department_id , SUM(salary )
FROM employees 
GROUP BY department_id ;
  1. SUM adalah grup berdasarkan fungsi karena memproses sekelompok karyawan yang bekerja di suatu departemen
  2. SUM adalah fungsi agregat karena menghasilkan satu hasil per grup data
  3. SUM adalah fungsi baris tunggal karena mengembalikan nilai tunggal untuk departemen yaitu grup
  4. SUM adalah grup dengan fungsi ekstensi karena menggunakan klausa GROUP BY untuk mengelompokkan departemen secara logis

Answer: A. SUM adalah fungsi grup yang menghitung jumlah gaji sekelompok karyawan yang bekerja di suatu departemen.

14. Which clause is used to filter the query output based on aggregated results using a group by function?

  1. WHERE
  2. LIMIT
  3. KELOMPOK DI MANA
  4. HAVING

Answer: D. HAVING Clause digunakan untuk membatasi hasil grup. Anda menggunakan klausa HAVING untuk menentukan grup yang akan ditampilkan, sehingga membatasi grup berdasarkan informasi agregat. Klausa HAVING bisa mendahului klausa GROUP BY, tetapi Anda disarankan untuk menempatkan klausa GROUP BY terlebih dahulu karena lebih logis. Grup dibentuk dan fungsi grup dihitung sebelum klausa HAVING diterapkan ke grup dalam daftar SELECT.

15. Examine the given table structure and predict the outcome of 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)
SELECT count(*)
FROM employees 
WHERE comm = NULL;
  1. Kueri mengembalikan jumlah karyawan yang tidak memiliki komisi
  2. Kueri memunculkan kesalahan karena tanda sama dengan tidak dapat digunakan saat mencari nilai NULL
  3. Kueri mengembalikan jumlah karyawan di departemen yang komisinya adalah nilai NULL
  4. Kueri memunculkan kesalahan karena klausa GROUP BY tidak ada dalam kueri

Answer: B. Mengecualikan NULL menggunakan kondisi WHERE adalah cara untuk mengarahkan kueri agar mengabaikan NULL. Namun disini penggunaan operator IS NULL salah. Kondisinya harus 'WHERE comm IS NULL'.

16. Which of the following statements is true about the group functions?

  1. Fungsi MIN hanya dapat digunakan dengan data numerik.
  2. Fungsi MAX hanya dapat digunakan dengan nilai tanggal.
  3. Fungsi AVG hanya dapat digunakan dengan data numerik.
  4. Fungsi SUM tidak bisa menjadi bagian dari fungsi bersarang.

Answer: C. Fungsi AVG hanya dapat digunakan dengan nilai numerik. Fungsi lain yang memiliki batasan tersebut adalah SUM, STDDEV dan VARIANCE.

17. Which of the following is a valid SELECT statement?

  1. SELECT AVG(retail-cost) FROM books GROUP BY category;
  2. SELECT category, AVG(retail-cost) FROM books;
  3. SELECT category, AVG(retail-cost) FROM books WHERE AVG(retail-cost) > 8.56 GROUP BY category;
  4. SELECT category, AVG(retail-cost) Profit FROM books GROUP BY category HAVING profit > 8.56;

Answer: A. Alias ​​kolom tidak dapat digunakan dalam klausa GROUP BY atau HAVING.

18. Which of the following statements is correct?

  1. Klausa WHERE dapat berisi fungsi grup hanya jika fungsinya juga tidak terdaftar dalam klausa SELECT.
  2. Fungsi grup tidak dapat digunakan dalam klausa SELECT, FROM, atau WHERE.
  3. Klausa HAVING selalu diproses sebelum klausa WHERE.
  4. Klausa GROUP BY selalu diproses sebelum klausa HAVING.

Answer: D. Meskipun Oracle tidak memunculkan kesalahan jika klausa HAVING mendahului klausa GROUP BY tetapi klausa GROUP BY diproses hanya setelah klausa GROUP BY diproses dan grup siap untuk difilter.

19. Which of the following is not a valid SQL statement?

  1. SELECT MIN(pubdate) FROM books GROUP BY category HAVING pubid = 4;
  2. SELECT MIN(pubdate) FROM books WHERE category = 'COOKING';
  3. SELECT COUNT(*) FROM orders WHERE customer# = 1005;
  4. SELECT MAX(COUNT(customer#)) FROM orders GROUP BY customer#;

Answer: A.

20. Which of the following statements is correct?

  1. Fungsi COUNT dapat digunakan untuk menentukan berapa banyak baris yang berisi nilai NULL.
  2. Hanya nilai berbeda yang disertakan dalam fungsi grup, kecuali kata kunci ALL disertakan dalam klausa SELECT.
  3. Klausa WHERE membatasi baris mana yang diproses.
  4. Klausa HAVING menentukan grup mana yang ditampilkan dalam hasil kueri.

Answer: C, D. Klausa WHERE membatasi baris sebelum dikelompokkan dan diproses, sedangkan klausa HAVING membatasi grup.

21. Which of the following is a valid SQL statement?

  1. SELECT customer#, order#, MAX(shipdate-orderdate) FROM orders GROUP BY customer# WHERE customer# = 1001;
  2. SELECT customer#, COUNT(order#) FROM orders GROUP BY customer#;
  3. SELECT customer#, COUNT(order#) FROM orders GROUP BY COUNT(order#);
  4. SELECT customer#, COUNT(order#) FROM orders GROUP BY order#;

Answer: B. Klausa GROUP BY harus berisi semua kolom kecuali yang digunakan di dalam fungsi grup.

22. Which of the following SELECT statements lists only the book with the largest profit?

  1. SELECT title, MAX(retail-cost) FROM books GROUP BY title;
  2. SELECT title, MAX(retail-cost) FROM books GROUP BY title HAVING MAX(retail-cost);
  3. SELECT title, MAX(retail-cost) FROM books;
  4. Bukan dari salah satu di atas

Answer: A.

23. Which of the following statement(s) is/are correct?

1. Fungsi grup dapat disarangkan di dalam fungsi grup.

2. Fungsi grup dapat disarangkan di dalam fungsi baris tunggal.

3. Fungsi baris tunggal dapat ditempatkan di dalam fungsi grup.

  1. 1
  2. 2
  3. 3
  4. 1 dan 3

Answer: A, B, C. Fungsi grup hanya dapat ditumpuk hingga kedalaman dua. Fungsi grup dapat disarangkan di dalam fungsi baris tunggal (AVG tertanam dalam fungsi TO_CHAR). Selain itu, fungsi baris tunggal dapat ditempatkan di dalam fungsi grup.

24. Which of the following functions is used to calculate the total value stored in a specified column?

  1. COUNT
  2. ADD
  3. TOTAL
  4. SUM

Answer: D. Fungsi SUM digunakan untuk mendapatkan penambahan nilai numerik.

25. Which of the following SELECT statements lists the highest retail price of all books in the Family category?

  1. SELECT MAX(retail) FROM books WHERE category = 'FAMILY';
  2. SELECT MAX(retail) FROM books HAVING category = 'FAMILY';
  3. SELECT retail FROM books WHERE category = 'FAMILY' HAVING MAX(retail);
  4. Bukan dari salah satu di atas

Answer: A. Karena kategori FAMILY harus dibatasi sebelum pengelompokan, baris tabel harus difilter menggunakan klausa WHERE dan bukan klausa HAVING.

26. Which of the following functions can be used to include NULL values in calculations?

  1. SUM
  2. NVL
  3. MAX
  4. MIN

Answer: B.NVL adalah fungsi umum untuk memberikan nilai alternatif ke nilai NULL. Ini benar-benar dapat membuat perbedaan dalam penghitungan aritmatika menggunakan fungsi grup AVG, STDDEV dan VARIANCE.

27. Which of the following is not a valid statement?

  1. Anda harus memasukkan kata kunci ALL dalam fungsi grup untuk memasukkan semua nilai duplikat.
  2. Fungsi AVG dapat digunakan untuk mencari perbedaan rata-rata yang dihitung antara dua tanggal.
  3. Fungsi MIN dan MAX dapat digunakan pada kolom VARCHAR2.
  4. Semua yang di atas

Answer: A. SEMUA kata kunci menghitung duplikat tetapi mengabaikan NULL. Duplikat juga disertakan dengan '*' dan spesifikasi nama kolom.

28. Which of the following SQL statements determines how many total customers were referred by other customers?

  1. SELECT customer#, SUM(referred) FROM customers GROUP BY customer#;
  2. SELECT COUNT(referred) FROM customers;
  3. SELECT COUNT(*) FROM customers;
  4. SELECT COUNT(*) FROM customers WHERE referred IS NULL;

Answer: B. Mempertimbangkan semua pelanggan sebagai satu grup, JUMLAH (dirujuk) hanya akan menghitung mereka yang dirujuk oleh seseorang. COUNT (direferensikan) akan mengabaikan nilai NULL kolom.

29. Determine the correct order of execution of following clauses in a SELECT statement.

1. PILIH

2. DARI

3. DI MANA

4. KELOMPOK OLEH

5. MEMILIKI

6. MEMESAN OLEH

  1. 2-3-4-5-1-6
  2. 1-2-3-4-5-6
  3. 6-5-4-3-2-1
  4. 5-4-2-3-1-6

Answer: A. Urutan pemrosesan dimulai dari klausa FROM untuk mendapatkan nama tabel, kemudian membatasi baris menggunakan klausa WHERE, mengelompokkannya menggunakan klausa GROUP BY, membatasi grup menggunakan klausa HAVING. Klausa ORDER BY adalah yang terakhir diproses untuk mengurutkan kumpulan data akhir.

30. Which of the below clauses is used to group a set of rows based on a column or set of columns?

  1. HAVING
  2. WHERE
  3. GRUP OLEH
  4. GROUPING

Answer: C. Klausa GROUP BY membentuk grup data berdasarkan daftar kolom yang ditentukan.

31. Which of the following group functions can be used for population variance and population standard deviation problems?

  1. VAR_POP
  2. STDDEV_POP
  3. VARIANCE
  4. STDDEV_SASMP

Answer: A, B.

32. Select the positions in a SELECT query where a group function can appear.

  1. Pernyataan SELECT
  2. Klausa WHERE
  3. ORDER BY klausa
  4. GROUP BY klausa

Answer: A, C, D. Fungsi grup dapat muncul di klausa SELECT, ORDER BY dan HAVING. Oracle memunculkan pengecualian jika fungsi grup digunakan dalam klausa WHERE atau GROUP BY.

33. Examine the structure of the EMPLOYEES table as given. Which query will return the minimum salary in each department?

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)
  1. SELECT department_id , MIN (salary ) from EMPLOYEES ;
  2. SELECT department_id , MIN (salary ) from EMPLOYEES  GROUP BY department_id ;
  3. SELECT department_id , MIN (salary ) from EMPLOYEES  GROUP BY salary ;
  4. SELECT department_id , MIN (salary ) from EMPLOYEES  GROUP BY employee_id ;

Answer: B. Fungsi MIN mengembalikan gaji minimum dalam kelompok yang dibentuk oleh departemen.

34. Examine the structure for the table EMPLOYEES and Interpret the output 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 COUNT(*), COUNT(all comm) FROM employees ;
  1. Ini melempar kesalahan karena hanya satu fungsi agregat yang dapat digunakan dalam kueri.
  2. Ini melempar kesalahan karena klausa GROUP BY hilang.
  3. Itu berhasil dijalankan dan mengembalikan nilai yang sama untuk keduanya.
  4. Ini dijalankan dengan sukses di mana COUNT (*) termasuk NULL dan COUNT (semua komunikasi) tidak termasuk NULL.

Answer: D.

35. Which of the following are true about group functions?

  1. Anda dapat menggunakan fungsi grup dalam klausa apa pun dari pernyataan SELECT.
  2. Anda dapat menggunakan fungsi grup hanya di daftar kolom dari klausa pemilihan dan di klausa WHERE dari pernyataan SELECT.
  3. Anda dapat mencampur kolom baris tunggal dengan fungsi grup dalam daftar kolom pernyataan SELECT dengan mengelompokkan pada kolom baris tunggal.
  4. Anda dapat mengirimkan nama kolom, ekspresi, konstanta, atau fungsi sebagai parameter ke fungsi grup.

Answer: C. Fungsi grup hanya dapat ditumpuk hingga kedalaman dua. Fungsi grup dapat disarangkan di dalam fungsi baris tunggal (AVG tertanam dalam fungsi TO_CHAR). Selain itu, fungsi baris tunggal dapat ditempatkan di dalam fungsi grup.

36. Examine the structure of the table EMPLOYEES as given. You want to create a "emp_dept_sales" view by executing the following SQL statements.

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)
CREATE VIEW emp_dept_sales
AS
SELECT d.department_name , sum(e.salary )
FROM employees  e, departments  d
where e.department_id =d.department_id 
GROUP by d.department_name ;

Pernyataan manakah yang benar tentang pelaksanaan pernyataan di atas?

  1. Tampilan akan dibuat dan Anda dapat melakukan operasi DLM pada tampilan
  2. Tampilan tidak akan dibuat karena pernyataan gabungan tidak diperbolehkan untuk membuat tampilan
  3. Tampilan tidak akan dibuat karena klausa GROUP BY tidak diperbolehkan untuk membuat tampilan
  4. Tampilan akan dibuat tetapi operasi DML tidak akan diizinkan pada tampilan

Answer: D. Aturan untuk Melakukan Operasi DML pada Tampilan. Anda tidak dapat menambahkan data melalui tampilan jika tampilan tersebut menyertakan fungsi grup atau klausa GROUP BY atau kata kunci DISTINCT. Kolom semu ROWNUM kata kunci Kolom yang ditentukan oleh ekspresi TIDAK NULL kolom di tabel dasar yang tidak dipilih oleh tampilan.

37. Which of the following statements are true regarding views?

  1. Sub query yang mendefinisikan tampilan tidak bisa menyertakan klausa GROUP BY
  2. Tampilan dibuat dengan sub query yang memiliki kata kunci DISTINCT dapat diperbarui
  3. Operasi Data Manipulation Language (DML) dapat dilakukan pada tampilan yang dibuat dengan sub query yang memiliki semua kolom NOT NULL dari sebuah tabel
  4. Tampilan yang dibuat dengan sub query yang memiliki kolom semu ROWNUM kata kunci tidak dapat diperbarui

Answer: C, D. Aturan untuk Melakukan Operasi DML pada Tampilan. Anda tidak dapat menambahkan data melalui tampilan jika tampilan tersebut menyertakan fungsi grup atau klausa GROUP BY atau kata kunci DISTINCT. Kolom semu ROWNUM kata kunci Kolom yang ditentukan oleh ekspresi TIDAK NULL kolom di tabel dasar yang tidak dipilih oleh tampilan.

38. Examine the table structure as given.

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)

Klausa manakah dalam kueri SQL di bawah ini yang menghasilkan kesalahan?

SELECT department_id , avg(salary )
FROM departments 
WHERE upper(job) in ('SALES','CLERK')
GROUP BY job
ORDER BY department_id ;
  1. WHERE
  2. SELECT
  3. DIPESAN OLEH
  4. GRUP OLEH

Answer: D. Klausa GROUP BY harus berisi semua kolom yang muncul di pernyataan SELECT. Ini menimbulkan kesalahan karena JOB bukan kolom yang dipilih. Seharusnya menggunakan DEPARTMENT_ID sebagai pengganti JOB.

39. Examine 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)

Manakah dari kueri SELECT di bawah ini yang akan menampilkan gaji maksimum dan minimum yang diperoleh oleh setiap kategori pekerjaan?

  1. SELECT job, MAX(salary ), MIN (salary ) FROM employees  GROUP BY department_id ;
  2. SELECT job, MAX(salary ), MIN (salary ) FROM employees  GROUP BY job;
  3. SELECT job, MAX(salary ), MIN (salary ) FROM employees ;
  4. Dua fungsi agregat tidak dapat digunakan bersama dalam pernyataan SELECT.

Answer: B. Lebih dari satu fungsi grup dapat muncul di pernyataan SELECT.

40. 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)

Periksa kesalahan dalam kueri di bawah ini.

SELECT department_id 
FROM employees 
WHERE hiredate > '01-JAN-1985'
AND COUNT(*) > 2
GROUP by department_id 
HAVING SUM (salary ) > 1000;
  1. Itu berhasil dijalankan dan menghasilkan hasil yang diperlukan.
  2. Ini menghasilkan kesalahan karena COUNT (*) harus ditentukan dalam klausa SELECT juga.
  3. Ini berhasil dijalankan tetapi tidak membuahkan hasil karena COUNT (prod_id) harus digunakan sebagai pengganti COUNT (*).
  4. Ini menghasilkan kesalahan karena COUNT (*) seharusnya hanya ada di klausa HAVING dan bukan di klausa WHERE.

Answer: D. Fungsi grup tidak dapat digunakan dalam klausa WHERE. Dapat muncul di klausa SELECT, HAVING dan ORDER BY.

41. Examine 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)

Memprediksi hasil dari kueri di bawah ini

SELECT job, COUNT(employee_id ),sum(salary )
FROM employees 
GROUP BY job
HAVING SUM (salary ) > 5000;
  1. Ini berhasil dijalankan dan mencantumkan jumlah karyawan di bawah setiap kategori pekerjaan tetapi mengabaikan klausul HAVING karena "gaji" tidak ada dalam klausul GROUP BY.
  2. Ini melempar kesalahan karena klausa HAVING tidak valid.
  3. Ini menimbulkan kesalahan karena "gaji" tidak termasuk dalam klausul GROUP BY.
  4. Ini berhasil dijalankan dan mencantumkan jumlah karyawan di bawah setiap kategori yang memiliki jumlah gaji lebih dari 5000.

Answer: D. Klausa HAVING membatasi hasil grup. Fungsi COUNT digunakan untuk menghitung sedangkan SUM digunakan untuk menambahkan nilai numerik.

42. What is true of using group functions on columns that contain NULL values?

  1. Fungsi grup pada kolom mengabaikan nilai NULL.
  2. Fungsi grup pada kolom yang mengembalikan tanggal mencakup nilai NULL.
  3. Fungsi grup pada kolom yang mengembalikan angka termasuk nilai NULL.
  4. Fungsi grup pada kolom tidak dapat digunakan secara akurat pada kolom yang berisi nilai NULL.

Answer: A. Kecuali fungsi COUNT, semua fungsi grup mengabaikan nilai NULL.

43. Which of the following statetments are true about the usage of GROUP BY columns in a subquery?

  1. Subkueri dapat berisi klausa GROUP BY dan ORDER BY.
  2. Subkueri tidak boleh berisi klausa GROUP BY dan ORDER BY.
  3. Subkueri dapat berisi ORDER BY tetapi tidak klausul GROUP BY.
  4. Subkueri tidak boleh berisi ORDER BY tetapi dapat memiliki klausa GROUP BY.

Answer: A. Seperti kueri utama, subkueri dapat berisi klausa GROUP BY serta ORDER BY.

Examine the table structure as given and answer the questions 44 to 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)

44. Predict the outcome of the below query

SELECT avg(max(salary ))
FROM employees 
GROUP BY department_id 
HAVING avg(max(salary ))>100;
  1. Itu berhasil dijalankan.
  2. Ini memberikan kesalahan karena klausa HAVING tidak valid.
  3. Ini memberikan kesalahan karena ekspresi GROUP BY tidak valid.
  4. Ini memberikan kesalahan karena fungsi agregat tidak dapat disarangkan dalam pernyataan SELECT.

Answer: B. Klausa HAVING tidak mengizinkan penumpukan fungsi agregat.

45. Predict the output of the below query

SELECT avg(salary ), department_id 
FROM employees 
GROUP BY department_id ;
  1. Ini memberikan kesalahan karena fungsi agregat tidak dapat muncul tepat setelah klausa SELECT.
  2. Ini memberikan kesalahan karena klausa GROUP BY tidak valid.
  3. Ini dijalankan tanpa kesalahan tetapi tidak menghasilkan keluaran.
  4. Itu berhasil dijalankan dan memberikan gaji rata-rata di setiap departemen.

Answer: D. Fungsi grup dapat digunakan dalam urutan apa pun (sebelum atau sesudah grup menurut kolom) dalam kueri SELECT.

46. Predict the output of the below query

SELECT lower(job),avg(salary )
FROM employees 
GROUP BY upper(job);
  1. Ini berhasil dijalankan dan menampilkan "pekerjaan" dalam huruf kecil.
  2. Ini berhasil dijalankan tetapi menampilkan "pekerjaan" dalam kasus aslinya.
  3. Ini melempar kesalahan karena fungsi baris tunggal dan agregat tidak dapat digunakan bersama.
  4. Ini melempar kesalahan karena konversi kasus dalam daftar SELECT tidak sesuai dengan kasus konversi klausa GROUP BY.

Answer: D. Fungsi LOWER, sebagai fungsi baris tunggal harus ditentukan dalam klausa GROUP BY untuk mendasarkan pengelompokan data EMPLOYEES.

47. Which of the below query executes successfully?

  1. SELECT employee_id , COUNT(hiredate-sysdate) FROM employees ;
  2. SELECT AVG(salary ), MAX(salary ) FROM employees ;
  3. SELECT AVG(salary ), MAX(salary ) FROM employees  GROUP BY department_id ;
  4. SELECT AVG(hiredate) FROM employees ;

Answer: B, C. Kueri pertama mengoperasikan seluruh data KARYAWAN sedangkan kueri kedua memproses data dalam kelompok departemen.

48. Identify the error in the below SELECT statement.

SELECT department_id , AVG (salary )
FROM employees 
GROUP BY department_id 
HAVING department_id  > 10;
  1. Ini dijalankan dengan sukses dan menampilkan gaji rata-rata departemen lebih tinggi dari 10.
  2. Ini melempar kesalahan karena kolom non agregat tidak dapat digunakan dalam klausa HAVING.
  3. Itu berhasil dijalankan tetapi menampilkan hasil yang salah untuk departemen.
  4. Ini melempar kesalahan karena klausa HAVING harus ditempatkan sebelum klausa GROUP BY.

Answer: A. Ekspresi GROUP BY dapat digunakan dalam klausa HAVING untuk memfilter grup dari kumpulan data akhir.

49. Predict the output of the below query

SELECT department_id , AVG (salary )
FROM employees 
GROUP BY department_id 
HAVING (department_id >10 and AVG(salary )>2000);
  1. Ini melempar kesalahan karena beberapa kondisi tidak dapat diberikan dalam klausa HAVING.
  2. Ini melempar kesalahan karena kolom non agregat tidak dapat digunakan dalam klausa HAVING.
  3. Ini dijalankan dengan sukses dan menampilkan gaji rata-rata departemen lebih tinggi dari 10 dan lebih besar dari 2000.
  4. Ini berhasil dijalankan tetapi tidak ada hasil yang ditampilkan.

Answer: C. Klausa HAVING dapat memberlakukan beberapa kondisi yang digabungkan menggunakan filter operator AND atau OR pada grup.

50. Which of the following group functions can be used with DATE values?

  1. AVG
  2. MIN
  3. SUM
  4. COUNT

Answer: B, D. Fungsi grup AVG dan SUM hanya dapat digunakan dengan data numerik.

51. Which of the following statements are true?

  1. AVG dan SUM hanya dapat digunakan dengan tipe data numerik.
  2. STDDEV dan VARIANCE hanya dapat digunakan dengan tipe data numerik.
  3. MAX dapat digunakan dengan tipe data LONG.
  4. MAX dan MIN tidak dapat digunakan dengan tipe data LOB atau LONG.

Answer: A, B, D. Fungsi grup AVG, SUM, VARIANCE, dan STDDEV hanya dapat digunakan dengan data numerik. Tak satu pun dari fungsi grup yang dapat digunakan dengan tipe data LONG.

52. Examine 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)

Identifikasi kesalahan dalam kueri di bawah ini.

SELECT department_id , avg(salary ), count(hiredate)
FROM employees 
GROUP BY department_id ;
  1. Beberapa fungsi agregat tidak dapat digunakan dalam satu kueri SELECT
  2. Klausa GROUP BY tidak valid
  3. Fungsi COUNT tidak dapat digunakan dengan nilai DATE
  4. Tidak ada kesalahan dan berhasil dijalankan

Answer: D.

53. Which of the following group function can be used with LOB data types?

  1. MAX
  2. MIN
  3. COUNT
  4. Tak ada satupun

Answer: D. Tidak ada fungsi agregat yang dapat digunakan dengan tipe data LOB.

54. Examine 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)

Memprediksi keluaran dari dua kueri di bawah ini

Query - 1

SELECT avg(comm)
FROM employees ;

Query - 2

SELECT avg(nvl(comm,0))
FROM employees ;
  1. Kedua kueri tersebut menghasilkan hasil yang sama
  2. Query - 1 dan Query - 2 menghasilkan hasil yang berbeda karena Query-1 menganggap nilai NULL dari COMM dan Query-2 menggantikan nilai NULL dari COMM dengan nol
  3. Query - 1 menghasilkan error karena COMM memiliki nilai NULL
  4. Kueri - 2 menghasilkan kesalahan karena NVL tidak dapat disarangkan dengan fungsi agregat.

Answer: B. Fungsi AVG mengabaikan nilai NULL saat menghitung rata-rata data numerik. AVG (kolom) akan menghitung rata-rata hanya untuk nilai bukan nol. Namun, jika NVL digunakan untuk mengganti NULL dengan nol, semua nilai akan dipertimbangkan.

55. Choose the correct statements about the GROUP BY clause.

  1. Alias ​​kolom dapat digunakan dalam klausa GROUP BY.
  2. Kolom GROUP BY harus ada di klausa SELECT.
  3. Klausa GROUP BY harus muncul bersama dengan klausa HAVING, sebuah kueri SELECT.
  4. Klausa GROUP BY harus muncul setelah klausa WHERE dalam kueri SELECT.

Answer: D. Sesuai urutan pemrosesan, klausa GROUP BY harus muncul setelah klausa WHERE dalam kueri SELECT.

56. Examine 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)

Memprediksi hasil dari kueri di bawah ini

SELECT department_id ,avg(salary )
FROM employees 
GROUP BY department_id , job
ORDER BY department_id ;
  1. Ini melempar kesalahan karena daftar kolom GROUP BY tidak cocok dengan daftar kolom SELECT.
  2. Itu berhasil dijalankan dan menghasilkan gaji rata-rata dari kategori pekerjaan di setiap departemen.
  3. Itu berhasil dijalankan dan menghasilkan gaji rata-rata untuk sebuah departemen di setiap kategori pekerjaan.
  4. Ini melempar kesalahan karena klausa GROUP BY dan ORDER BY memiliki daftar kolom yang berbeda.

Answer: B. Meskipun klausa GROUP BY secara implisit mengurutkan grup, klausa GROUP BY dan ORDER BY dapat digunakan bersama dalam kueri.

57. Which clause should you use to exclude group results in a query using group functions?

  1. WHERE
  2. HAVING
  3. GRUP OLEH
  4. DIPESAN OLEH

Answer: B. Klausa HAVING digunakan untuk membatasi grup.

Examine the table structure as given and answer the questions 58 and 59 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)

58. Predict the outcome of the below query

SELECT department_id ,avg(salary )
FROM employees 
HAVING avg(salary )>2000
GROUP BY department_id 
ORDER BY department_id
  1. Itu berhasil dijalankan.
  2. Ini melempar kesalahan karena klausa HAVING mendahului klausa GROUP BY.
  3. Ini melempar kesalahan karena klausa HAVING menggunakan fungsi agregat.
  4. Ini dijalankan tetapi tidak ada hasil yang ditampilkan karena klausa HAVING mendahului klausa GROUP BY.

Answer: A. Klausa HAVING dapat mendahului klausa GROUP BY tetapi klausa ini diproses hanya setelah hasil grup dihitung.

59. Predict the outcome of the below query

SELECT department_id , COUNT(first_name )
FROM employees 
WHERE job IN ('SALESMAN','CLERK','MANAGER','ANALYST')
GROUP BY department_id 
HAVING AVG(salary ) BETWEEN 2000 AND 3000;
  1. Ini mengembalikan kesalahan karena operator BETWEEN tidak dapat digunakan dalam klausa HAVING.
  2. Ini mengembalikan kesalahan karena klausa WHERE dan HAVING tidak dapat digunakan dalam pernyataan SELECT yang sama.
  3. Ini mengembalikan kesalahan karena klausa WHERE dan HAVING tidak dapat digunakan untuk menerapkan kondisi pada kolom yang sama.
  4. Itu berhasil dijalankan.

Answer: D. Klausa WHERE membatasi jumlah baris yang berpartisipasi dalam pemrosesan klausa grup.

60. Which statements are true regarding the WHERE and HAVING clauses in a SELECT statement?

  1. Klausa HAVING dapat digunakan dengan fungsi grup di subkueri.
  2. Klausa WHERE dapat digunakan untuk mengecualikan baris setelah membaginya menjadi beberapa grup.
  3. Klausa WHERE dapat digunakan untuk mengecualikan baris sebelum membaginya menjadi beberapa grup.
  4. Klausa WHERE dan HAVING dapat digunakan dalam pernyataan yang sama hanya jika diterapkan ke kolom yang berbeda dalam tabel.

Answer: A, C. Klausa WHERE dan HAVING dapat digunakan bersama dalam kueri. WHERE mengecualikan baris sebelum pemrosesan grup sementara HAVING membatasi grup.

Examine the table structure as given and answer the questions 61 and 62 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)

61. Predict the outcome of the below query.

SELECT department_id , avg(salary )
FROM employees 
HAVING avg(salary ) > min(salary )
GROUP BY department_id ;
  1. Itu melempar kesalahan karena fungsi agregat yang digunakan dalam klausa HAVING harus dalam daftar SELECT.
  2. Ini melontarkan kesalahan karena klausa HAVING muncul sebelum klausa GROUP BY.
  3. Ini menampilkan departemen yang gaji rata-rata lebih besar dari gaji minimum departemen.
  4. Ini menampilkan departemen yang gaji rata-rata lebih besar dari gaji minimum organisasi.

Answer: C. Fungsi grup dapat digunakan oleh klausa HAVING untuk memfilter grup.

62. Interpret the output of the below query.

SELECT SUM(AVG(LENGTH(first_name )))
FROM employees  
GROUP BY department_id ;
  1. Ini menghitung jumlah rata-rata panjang nama karyawan di setiap departemen.
  2. Ini menghitung panjang rata-rata nama karyawan di setiap departemen.
  3. Ini melempar kesalahan karena fungsi baris tunggal tidak dapat digunakan dengan fungsi grup.
  4. Ini melempar kesalahan karena kolom grup DEPARTMENT_ID tidak digunakan dalam daftar SELECT.

Answer: A. Fungsi grup dapat digunakan dengan satu baris atau fungsi umum dalam kueri SELECT.

63. Up to how many levels, the group functions can be nested?

  1. 1
  2. 2
  3. 3
  4. Tanpa batas

Answer: B. Fungsi grup dapat disarangkan maksimal hingga 2 level. Namun, fungsi baris tunggal dapat disarangkan hingga sejumlah level.

64. What is the limit of number of groups within the groups created by GROUP BY clause?

  1. 1
  2. 2
  3. 3
  4. Tidak terbatas

Answer: D. Tidak ada batasan jumlah kelompok dan subkelompok yang dapat dibentuk.

65. Choose the correct statements about the HAVING clause.

  1. Klausa HAVING adalah klausa opsional dalam pernyataan SELECT.
  2. Klausa HAVING adalah klausa wajib jika pernyataan SELECT menggunakan klausa GROUP BY.
  3. Klausa HAVING dapat muncul dalam pernyataan SELECT hanya jika menggunakan klausa GROUP BY.
  4. Klausa HAVING adalah klausa wajib jika pernyataan SELECT menggunakan klausa GROUP BY.

Answer: A, C. Klausa HAVING hanya dapat muncul dalam kueri jika klausa GROUP BY ada, tetapi sebaliknya tidak benar.

66. What is the output of the below query.

SELECT count(*) FROM dual GROUP BY dummy;
  1. 1
  2. 0
  3. NULL
  4. Melempar kesalahan karena fungsi grup tidak dapat diterapkan pada tabel DUAL.

Answer: A. Tabel DUAL berisi kolom tunggal DUMMY tipe CHAR (1) yang nilainya adalah 'X'.

Based on the below scenario, answer the question from 67 to 74.

Sebuah organisasi memiliki 14 karyawan yang bekerja dengan gaji tetap 1000. Perusahaan merekrut 5 karyawan baru yang gajinya belum ditetapkan oleh bagian penggajian. Namun, selama pemrosesan akhir bulan, departemen penggajian SDM menghasilkan beberapa laporan untuk merekonsiliasi data keuangan organisasi. Periksa struktur tabel seperti yang diberikan.

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)

67. What is the output of the below query?

SELECT SUM (salary ) FROM employees ;
  1. NULL
  2. 14000
  3. 19000
  4. 0

Answer: B. Fungsi SUM menambahkan gaji karyawan.

68. What is the output of the below query?

SELECT AVG (salary ) FROM employees ;
  1. 1000
  2. 736.84
  3. NULL
  4. 0

Answer: A. Fungsi AVG (gaji) menghitung rata-rata gaji dan mengabaikan nilai NULL. Dalam hal ini, AVG (gaji) = (14 * 1000) / 14 = 1000.

69. What is the output of the below query?

SELECT AVG (nvl(salary ,0)) FROM employees ;
  1. 1000
  2. NULL
  3. 736.84
  4. 0

Answer: C. AVG (NVL (gaji, 0)) memberikan nilai alternatif pada NULL dan memungkinkan mereka untuk berpartisipasi dalam penghitungan rata-rata. Dalam hal ini, (14 * 1000) / 19 = 736,84.

70. What is the output of the below query?

SELECT VARIANCE (salary ) FROM employees ;
  1. 1000
  2. 0
  3. NULL
  4. 204678.36

Answer: B. VARIANCE (gaji) menghitung varians nilai kolom gaji dengan mengabaikan NULL.

71. What is the output of the below query?

SELECT VARIANCE (nvl(salary ,0)) FROM employees ;
  1. 1000
  2. 0
  3. NULL
  4. 204678.36

Answer: D. VARIANCE (NL (gaji, 0)) menghitung varians dari nilai kolom gaji termasuk NULL.

72. What is the output of the below query?

SELECT STDDEV (salary ) FROM employees ;
  1. 1
  2. 1000
  3. 0
  4. NULL

Answer: C. STDDEV (gaji) menghitung deviasi standar dari nilai kolom gaji dengan mengabaikan NULL.

73. What is the output of the below query?

SELECT STDDEV (nvl(salary ,0)) FROM employees ;
  1. 0
  2. 452.41
  3. 1000
  4. NULL

Answer: B. STDDEV (nvl (gaji, 0)) menghitung deviasi standar dari nilai kolom gaji termasuk NULL.

74. What is the output of the below query?

  1. 19,19
  2. 14,19
  3. 19,14
  4. 14,14

Answer: C. COUNT (*) termasuk NULL sementara COUNT (gaji) mengabaikan nilai NULL.

75. Examine 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)

Manakah dari kueri di bawah ini yang akan memberikan departemen yang memiliki lebih dari 5 karyawan yang bekerja di dalamnya?

  1. SELECT department_id  FROM employees  WHERE COUNT(*) > 5 GROUP BY department_id ;
  2. SELECT department_id  FROM employees  HAVING COUNT(*) > 5;
  3. SELECT department_id  FROM employees  GROUP BY employee_id  HAVING COUNT(*) > 5;
  4. SELECT department_id  FROM employees  GROUP BY department_id  HAVING COUNT(*) > 5;

Answer: D.

76. Which of the following are true about the CUBE extension of GROUP BY?

  1. Memungkinkan melakukan beberapa klausa GROUP BY dengan satu kueri.
  2. Melakukan agregasi untuk semua kemungkinan kombinasi kolom yang disertakan.
  3. Melakukan peningkatan tingkat subtotal kumulatif, berdasarkan daftar kolom yang disediakan.
  4. Bukan dari salah satu di atas

Answer: B. CUBE, ROLLUP adalah ekstensi GROUP BY yang digunakan untuk pemrosesan OLAP. CUBE mengumpulkan hasil setiap kali permutasi kolom baru terbentuk.

Use the following SELECT statement to answer below questions 77 to 82:

1 SELECT customer#, COUNT(*)
2 FROM customers JOIN orders USING (customer#)
3 WHERE orderdate > '02-APR-09'
4 GROUP BY customer#
5 HAVING COUNT(*) > 2;

77. Which line of the SELECT statement is used to restrict the number of records the query processes?

  1. 1
  2. 3
  3. 4
  4. 5

Answer: B. Klausa WHERE digunakan untuk membatasi baris sebelum grup dibentuk.

78. Which line of the SELECT statement is used to restrict groups displayed in the query results?

  1. 1
  2. 3
  3. 4
  4. 5

Answer: D. HAVING digunakan untuk membatasi hasil grup setelah pemrosesan grup selesai.

79. Which line of the SELECT statement is used to group data stored in the database?

  1. 1
  2. 3
  3. 4
  4. 5

Answer: C. Klausa GROUP BY menggunakan grup menurut kolom untuk mengelompokkan data dalam tabel.

80. Which clause must be included for the query to execute successfully?

  1. 1
  2. 3
  3. 4
  4. 5

Answer: C. Karena klausa SELECT berisi kolom CUSTOMER #, maka wajib memiliki klausa GROUP BY dengan kolom CUSTOMER #.

81. What is the purpose of using COUNT(*) in the SELECT query?

  1. Jumlah record dalam tabel yang ditentukan
  2. Jumlah pesanan yang dilakukan oleh setiap pelanggan
  3. Jumlah nilai NULL dalam tabel yang ditentukan
  4. Jumlah pelanggan yang telah melakukan pemesanan

Answer: B. Ini menghitung jumlah baris yang diproses di bawah grup. Dalam hal ini, grup dibentuk oleh pelanggan dan JUMLAH (*) menghitung pesanan yang dilakukan oleh setiap pelanggan.

82. Which of the following functions can be used to determine the earliest ship date for all orders recently processed by JustLee Books?

  1. Fungsi COUNT
  2. Fungsi MAX
  3. Fungsi MIN
  4. Fungsi STDDEV

Answer: C. Fungsi MIN digunakan untuk mengambil nilai terkecil dari kolom tersebut. Saat digunakan dengan kolom tanggal, ini mengambil tanggal minimum dari kolom.

83. Which of the following is not a valid SELECT statement?

  1. SELECT STDDEV(retail) FROM books;
  2. SELECT AVG(SUM(retail)) FROM orders NATURAL JOIN orderitems NATURAL JOIN books GROUP BY customer#;
  3. SELECT order#, TO_CHAR(SUM(retail),'999.99') FROM orderitems JOIN books USING (isbn) GROUP BY order#;
  4. SELECT title, VARIANCE(retail-cost) FROM books GROUP BY pubid;

Answer: D. Klausa GROUP BY harus menentukan kolom atau kumpulan kolom yang terdapat dalam klausa SELECT. Di sini PUBID tidak terdapat dalam klausa SELECT, oleh karena itu kueri tersebut tidak valid.

84. Which of the below statements are true about the nesting of group functions?

  1. Fungsi paling dalam diselesaikan terlebih dahulu.
  2. Oracle memungkinkan penumpukan fungsi grup hingga 3 level.
  3. Fungsi baris tunggal dapat disarangkan dengan fungsi grup.
  4. Oracle memungkinkan penumpukan fungsi grup hingga 2 level.

Answer: A, C, D. Dalam ekspresi yang berisi fungsi bertingkat, fungsi paling dalam dijalankan terlebih dahulu yang hasilnya diumpankan ke fungsi berikutnya yang bergerak ke arah luar. Fungsi baris tunggal dapat digunakan dengan baik dengan fungsi grup yang dapat bertumpuk maksimal hingga 2 level.

85. What are the statistical group functions in Oracle?

  1. AVG
  2. STDDEV
  3. VARIANCE
  4. STATS

Answer: B, C. VARIANCE dan STATS adalah fungsi grup statistik yang tersedia di Oracle SQL.

86. If the SELECT list contains a column and a group functions, which of the following clause must be mandatorily included?

  1. DIPESAN OLEH
  2. HAVING
  3. GRUP OLEH
  4. Tak ada satupun

Answer: C. Klausa GROUP BY harus berisi kolom atau kumpulan kolom yang terdapat dalam klausa SELECT.

87. Examine 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)

Apa penjelasan terbaik tentang mengapa pernyataan SQL ini TIDAK akan dijalankan?

SELECT department_id "Department", AVG (salary)"Average"
FROM employees
GROUP BY Department;
  1. Gaji tidak dapat dirata-ratakan karena tidak semua angka akan dibagi rata.
  2. Anda tidak dapat menggunakan alias kolom di klausa GROUP BY.
  3. Klausul GROUP BY harus memiliki sesuatu untuk GROUP.
  4. Id departemen tidak terdaftar di tabel departemen.

Answer: B. Baik klausa GROUP BY maupun klausa HAVING tidak berfungsi dengan alias kolom.

88. Which of the following data types are compatible with AVG, SUM, VARIANCE, and STDDEV functions?

  1. Hanya tipe data numerik
  2. Bilangan bulat saja
  3. Tipe data apa pun
  4. Semua kecuali numerik

Answer: A. Fungsi AVG, SUM, VARIANCE, dan STDDEV wajib bekerja hanya dengan tipe data numerik.

Examine the table structure as given below and answer the questions 89 and 90 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)

89. Which of the below query will display the number of distinct job categories working in each department?

  1. SELECT department_id , COUNT(DISTINCT job) FROM employees  GROUP BY job;
  2. SELECT department_id , COUNT(job) FROM employees  GROUP BY employee_id ;
  3. SELECT department_id , COUNT(job) FROM employees  GROUP BY department_id ;
  4. SELECT department_id , COUNT(DISTINCT job) FROM employees  GROUP BY department_id ;

Answer: D. Gunakan pengubah DISTINCT untuk memfilter duplikat.

90. Evaluate this SQL statement:

SELECT employee_id , first_name , department_id , SUM(salary )
FROM employees 
WHERE salary  > 1000
GROUP BY department_id , employee_id , first_name 
ORDER BY hiredate;

Mengapa pernyataan ini menyebabkan kesalahan?

  1. Klausa HAVING hilang.
  2. Klausa WHERE berisi kesalahan sintaksis.
  3. Kolom GAJI TIDAK termasuk dalam klausul GROUP BY.
  4. Kolom HIRE_DATE TIDAK termasuk dalam klausa GROUP BY.

Answer: D. Semua kolom yang muncul di klausa SELECT dan ORDER BY harus disertakan dalam klausa GROUP BY.

91. Which of the following statements is true about the GROUP BY clause?

  1. Untuk mengecualikan baris sebelum membaginya menjadi kelompok menggunakan klausa GROUP BY, Anda harus menggunakan klausa WHERE.
  2. Anda harus menggunakan klausa HAVING dengan klausa GROUP BY.
  3. Alias ​​kolom dapat digunakan dalam klausa GROUP BY.
  4. Secara default, baris tidak diurutkan ketika klausa GROUP BY digunakan.

Answer: A. Dengan menggunakan klausa WHERE, Anda dapat mengecualikan baris sebelum membaginya menjadi beberapa grup.

92. Examine 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)

Tafsirkan hasil dari kueri di bawah ini.

SELECT department_id , MIN (hiredate)
FROM employees 
GROUP by department_id ;
  1. Tanggal perekrutan paling awal di organisasi.
  2. Tanggal perekrutan terakhir di organisasi.
  3. Tanggal perekrutan paling awal di sebuah departemen.
  4. Tanggal perekrutan terakhir di sebuah departemen.

Answer: C. Kueri mengembalikan karyawan yang direkrut paling awal di setiap departemen.

93. Which statement about group functions is true?

  1. Fungsi grup kecuali COUNT (*), abaikan nilai null.
  2. Kueri yang menyertakan fungsi grup dalam daftar PILIH harus menyertakan klausa GROUP BY.
  3. Fungsi grup dapat digunakan dalam klausa WHERE.
  4. Fungsi grup hanya dapat digunakan dalam daftar PILIHAN.

Answer: A. Semua fungsi grup kecuali COUNT (*), abaikan nilai NULL. Itu karena mereka memproses nilai-nilai yang terkandung secara langsung di kolom tertentu.

94. Which of the following clauses represent valid uses of group functions?

  1. GROUP BY MAX (gaji)
  2. ORDER BY AVG (gaji)
  3. HAVING MAX (gaji)> 10.000
  4. PILIH AVG (NVL (gaji, 0))

Answer: B, C, D. Fungsi grup hanya dapat muncul di klausa SELECT, HAVING dan ORDER BY.

95. Which of the following statements are true about the GROUP BY clause?

  1. Kolom terakhir yang terdaftar dalam klausa GROUP BY adalah pengelompokan paling utama.
  2. Kolom pertama yang terdaftar di klausa GROUP BY adalah pengelompokan paling utama.
  3. Klausa GROUP BY tidak dapat digunakan tanpa klausa ORDER BY.
  4. Klausa GROUP BY tidak memastikan pengurutan keluaran.

Answer: B. Pengelompokan data didasarkan pada urutan kolom yang muncul pada klausa GROUP BY.

96. What is difference between WHERE clause and HAVING clause?

  1. Klausa WHERE membatasi baris sebelum pengelompokan sedangkan klausa HAVING membatasi kelompok.
  2. Klausa WHERE tidak dapat berisi fungsi grup tetapi klausa HAVING dapat memiliki.
  3. Klausa WHERE dapat menggabungkan beberapa kondisi menggunakan operator AND atau OR tetapi klausa HAVING tidak bisa.
  4. Klausa WHERE bisa muncul di kueri SELECT tanpa klausa GROUP BY tetapi klausa HAVING tidak bisa.

Answer: A, B, D. Klausa WHERE membatasi baris sebelum pengelompokan tetapi HAVING membatasi kelompok.

97. Examine 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)

Memprediksi hasil dari kueri di bawah ini.

SELECT department_id ,job,count(*)
FROM employees 
GROUP BY department_id ,job
ORDER BY department_id ,count(*);
  1. Itu berhasil dijalankan.
  2. Ini melempar kesalahan karena klausa ORDER BY tidak valid.
  3. Ini melempar kesalahan karena klausa GROUP BY tidak valid.
  4. Ini melempar kesalahan karena klausa GROUP BY dan ORDER BY tidak dapat digunakan bersama.

Answer: A. Klausa ORDER BY dapat menggunakan fungsi grup untuk pengurutan.