Menggunakan fungsi Grup
Melaporkan data Agregat menggunakan fungsi Grup
SQL memiliki banyak fungsi agregat yang telah ditentukan sebelumnya yang dapat digunakan untuk menulis kueri untuk menghasilkan jenis informasi yang tepat. Klausa GROUP BY menentukan cara mengelompokkan baris dari tabel data saat menggabungkan informasi, sementara klausa HAVING memfilter baris yang tidak termasuk dalam kelompok tertentu.
Fungsi agregat melakukan berbagai tindakan seperti menghitung semua baris dalam tabel, menghitung rata-rata data kolom, dan menjumlahkan data numerik. Agregat juga dapat menelusuri tabel untuk menemukan nilai "MAX" tertinggi atau "MIN" terendah dalam kolom. Seperti jenis kueri lainnya, Anda dapat membatasi, atau memfilter baris yang ditindaklanjuti oleh fungsi ini dengan klausa WHERE. Misalnya, jika seorang manajer perlu mengetahui berapa banyak karyawan yang bekerja dalam sebuah organisasi, fungsi agregat bernama COUNT (*) dapat digunakan untuk menghasilkan informasi ini. Fungsi COUNT (*) yang diperlihatkan dalam pernyataan SELECT di bawah menghitung semua baris dalam a meja.
SELECT COUNT(*)
FROM employees;
COUNT(*)
----------
24
Tabel hasil untuk fungsi COUNT (*) adalah satu kolom dari satu baris yang dikenal sebagai hasil atau nilai skalar. Perhatikan bahwa tabel hasil memiliki judul kolom yang sesuai dengan nama fungsi agregat yang ditentukan dalam klausa SELECT.
Beberapa fungsi agregat yang umum digunakan adalah sebagai berikut -
SUM( [ALL | DISTINCT] expression )
AVG( [ALL | DISTINCT] expression )
COUNT( [ALL | DISTINCT] expression )
COUNT(*)
MAX(expression)
MIN(expression)
Kata kunci ALL dan DISTINCT bersifat opsional, dan melakukan seperti yang mereka lakukan dengan klausa SELECT yang telah Anda pelajari untuk menulis. Kata kunci ALL adalah default di mana opsi diizinkan. Ekspresi yang tercantum dalam sintaks dapat berupa konstanta, fungsi, atau kombinasi nama kolom, konstanta, dan fungsi apa pun yang dihubungkan oleh operator aritmatika. Namun, fungsi agregat paling sering digunakan dengan nama kolom. Kecuali fungsi COUNT, semua fungsi agregat tidak mempertimbangkan nilai NULL.
Ada dua aturan yang harus Anda pahami dan ikuti saat menggunakan agregat:
Fungsi agregat dapat digunakan di klausa SELECT dan HAVING (klausa HAVING akan dibahas nanti di bab ini).
Fungsi agregat tidak dapat digunakan dalam klausa WHERE. Pelanggarannya akan menghasilkan fungsi grup Oracle ORA-00934 tidak diperbolehkan di sini pesan kesalahan.
Ilustrasi
Kueri SELECT di bawah menghitung jumlah karyawan di organisasi.
SELECT COUNT(*) Count
FROM employees;
COUNT
-----
24
Kueri SELECT di bawah ini mengembalikan rata-rata gaji karyawan di organisasi.
SELECT AVG(Salary) average_sal
FROM employees;
AVERAGE_SAL
-----------
15694
Kueri PILIH di bawah ini mengembalikan jumlah gaji karyawan di organisasi.
SELECT SUM(Salary) total_sal
FROM employees;
TOTAL_SAL
---------
87472
Kueri SELECT di bawah mengembalikan tanggal karyawan terlama dan terbaru di organisasi.
SELECT MIN (hire_date) oldest, MAX (hire_date) latest
FROM employees;
OLDEST LATEST
--------- -----------
16-JAN-83 01-JUL-2012
GRUP OLEH
Fungsi agregat biasanya digunakan bersama dengan klausa GROUP BY. Klausa GROUP BY memungkinkan Anda menggunakan fungsi agregat untuk menjawab pertanyaan manajerial yang lebih kompleks seperti:
Berapa gaji rata-rata karyawan di setiap departemen?
Berapa banyak karyawan yang bekerja di setiap departemen?
Berapa banyak karyawan yang mengerjakan proyek tertentu?
Mengelompokkan menurut fungsi membuat grup data berdasarkan kolom dan menggabungkan informasi dalam grup saja. Kriteria pengelompokan ditentukan oleh kolom yang ditentukan dalam klausa GROUP BY. Mengikuti hierarki ini, data pertama-tama diatur dalam grup dan kemudian klausa WHERE membatasi baris di setiap grup.
Panduan penggunaan klausa GROUP BY
(1) Semua kolom atau kolom dependen yang digunakan dalam fungsi GROUP BY harus menjadi dasar pengelompokan, karenanya harus dimasukkan dalam klausa GROUP BY juga.
SELECT DEPARTMENT_ID, SUM(SALARY)
FROM employees;
DEPARTMENT_ID,
*
ERROR at line 2:
ORA-00937: not a single-group group function
(2) Klausa GROUP BY tidak mendukung penggunaan alias kolom, tetapi nama sebenarnya.
(3) Klausa GROUP BY hanya dapat digunakan dengan fungsi agregat seperti SUM, AVG, COUNT, MAX, dan MIN. Jika digunakan dengan fungsi baris tunggal, Oracle akan menampilkan pengecualian sebagai "ORA-00979: bukan ekspresi GROUP BY" .
(4) Fungsi agregat tidak dapat digunakan dalam klausa GROUP BY. Oracle akan mengembalikan pesan kesalahan "ORA-00934: grup fungsi tidak diizinkan" di sini.
Kueri di bawah ini mencantumkan jumlah karyawan yang bekerja di setiap departemen.
SELECT DEPARTMENT_ID, COUNT (*)
FROM employees
GROUP BY DEPARTMENT_ID;
Demikian pula, kueri di bawah ini untuk menemukan jumlah gaji untuk masing-masing id pekerjaan di setiap departemen. Perhatikan bahwa grup dibentuk berdasarkan Departemen dan Job id. Jadi mereka muncul di klausa GROUP BY.
SELECT DEPARTMENT_ID, JOB_ID, SUM (SAL)
FROM employees
GROUP BY DEPARTMENT_ID, JOB_ID;
Kueri di bawah ini juga menghasilkan hasil yang sama. Harap dicatat bahwa pengelompokan didasarkan pada kolom id departemen dan id pekerjaan tetapi tidak digunakan untuk tujuan tampilan.
SELECT SUM (SALARY)
FROM employees
GROUP BY DEPARTMENT_ID, JOB_ID;
Penggunaan DISTINCT, SEMUA kata kunci dengan fungsi Agregat
Dengan menentukan kata kunci DISTINCT dengan parameter input, kelompok menurut fungsi hanya mempertimbangkan nilai unik kolom untuk agregasi. Dengan menentukan SEMUA kata kunci dengan parameter input, kelompok berdasarkan fungsi mempertimbangkan semua nilai kolom untuk agregasi, termasuk null dan duplikat. SEMUA adalah spesifikasi default.
Klausa HAVING
Klausa HAVING digunakan untuk fungsi agregat dengan cara yang sama seperti klausa WHERE digunakan untuk nama dan ekspresi kolom. Pada dasarnya, klausa HAVING dan WHERE melakukan hal yang sama, yaitu memfilter baris dari penyertaan dalam tabel hasil berdasarkan kondisi . Meskipun terlihat bahwa klausa HAVING memfilter grup, namun klausa HAVING tidak memfilter baris.
Ketika semua baris untuk grup dieliminasi, begitu juga grup. Singkatnya, perbedaan penting antara klausa WHERE dan HAVING adalah:
Klausa WHERE digunakan untuk memfilter baris SEBELUM tindakan PENGELOMPOKAN (yaitu, sebelum penghitungan fungsi agregat).
Klausa HAVING memfilter baris SETELAH tindakan PENGELOMPOKAN (yaitu, setelah penghitungan fungsi agregat).
SELECT JOB_ID, SUM (SALARY)
FROM employees
GROUP BY JOB_ID
HAVING SUM (SALARY) > 10000;
Klausa HAVING adalah opsi bersyarat yang secara langsung terkait dengan opsi klausa GROUP BY karena klausa HAVING menghilangkan baris dari tabel hasil berdasarkan hasil klausa GROUP BY.
SELECT department_id, AVG(Salary)
FROM employees
HAVING AVG(Salary) > 33000;
ERROR at line 1: ORA-00937: not a single-group group function