Impala - Urutan Berdasarkan Klausul

Impala ORDER BYklausa digunakan untuk mengurutkan data dalam urutan naik atau turun, berdasarkan satu atau beberapa kolom. Beberapa database mengurutkan hasil kueri dalam urutan menaik secara default.

Sintaksis

Berikut adalah sintaks dari klausa ORDER BY.

select * from table_name ORDER BY col_name [ASC|DESC] [NULLS FIRST|NULLS LAST]

Anda dapat menyusun data dalam tabel dalam urutan menaik atau menurun menggunakan kata kunci ASC atau DESC masing-masing.

Dengan cara yang sama, jika kita menggunakan NULLS FIRST, semua nilai null di tabel diatur di baris atas; dan jika kita menggunakan NULLS LAST, baris yang berisi nilai null akan diatur terakhir.

Contoh

Asumsikan kita memiliki tabel bernama customers di database my_db dan isinya adalah sebagai berikut -

[quickstart.cloudera:21000] > select * from customers;
Query: select * from customers 
+----+----------+-----+-----------+--------+ 
| id | name     | age | address   | salary | 
+----+----------+-----+-----------+--------+ 
| 3  | kaushik  | 23  | Kota      | 30000  | 
| 1  | Ramesh   |  32 | Ahmedabad | 20000  | 
| 2  | Khilan   | 25  | Delhi     | 15000  | 
| 6  | Komal    | 22  | MP        | 32000  | 
| 4  | Chaitali | 25  | Mumbai    | 35000  | 
| 5  | Hardik   | 27  | Bhopal    | 40000  | 
+----+----------+-----+-----------+--------+ 
Fetched 6 row(s) in 0.51s

Berikut adalah contoh penyusunan data pada file customers tabel, dalam urutan menaik id’s menggunakan order by ayat.

[quickstart.cloudera:21000] > Select * from customers ORDER BY id asc;

Saat menjalankan, kueri di atas menghasilkan keluaran sebagai berikut.

Query: select * from customers ORDER BY id asc 
+----+----------+-----+-----------+--------+ 
| id | name     | age | address   | salary | 
+----+----------+-----+-----------+--------+ 
| 1  | Ramesh   | 32  | Ahmedabad | 20000  | 
| 2  | Khilan   | 25  | Delhi     | 15000  | 
| 3  | kaushik  | 23  | Kota      | 30000  | 
| 4  | Chaitali | 25  | Mumbai    | 35000  | 
| 5  | Hardik   | 27  | Bhopal    | 40000  | 
| 6  | Komal    | 22  | MP        | 32000  | 
+----+----------+-----+-----------+--------+ 
Fetched 6 row(s) in 0.56s

Dengan cara yang sama, Anda dapat mengatur data customers tabel dalam urutan menurun menggunakan order by klausa seperti yang ditunjukkan di bawah ini.

[quickstart.cloudera:21000] > Select * from customers ORDER BY id desc;

Saat menjalankan, kueri di atas menghasilkan keluaran sebagai berikut.

Query: select * from customers ORDER BY id desc 
+----+----------+-----+-----------+--------+ 
| id | name     | age | address   | salary | 
+----+----------+-----+-----------+--------+ 
| 6  | Komal    | 22  | MP        | 32000  | 
| 5  | Hardik   | 27  | Bhopal    | 40000  | 
| 4  | Chaitali | 25  | Mumbai    | 35000  | 
| 3  | kaushik  | 23  | Kota      | 30000  | 
| 2  | Khilan   | 25  | Delhi     | 15000  |
| 1  | Ramesh   | 32  | Ahmedabad | 20000  | 
+----+----------+-----+-----------+--------+ 
Fetched 6 row(s) in 0.54s