Impala - Klausul Offset

Secara umum, baris dalam kumpulan hasil a select kueri dimulai dari 0. Menggunakan offsetklausul, kita dapat memutuskan dari mana output harus dipertimbangkan. Sebagai contoh, jika kita memilih offset sebagai 0 maka hasilnya akan seperti biasa dan jika kita memilih offset 5, maka hasilnya dimulai dari baris kelima.

Sintaksis

Berikut ini adalah sintaks dari file offsetklausul di Impala.

select data from table_name Group BY col_name;

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  | 
| 6  | Komal    | 22  | MP        | 32000  | 
| 1  | Ramesh   | 32  | Ahmedabad | 20000  | 
| 5  | Hardik   | 27  | Bhopal    | 40000  | 
| 2  | Khilan   | 25  | Delhi     | 15000  | 
| 8  | ram      | 22  | vizag     | 31000  | 
| 9  | robert   | 23  | banglore  | 28000  |
| 7  | ram      | 25  | chennai   | 23000  | 
| 4  | Chaitali | 25  | Mumbai    | 35000  | 
+----+----------+-----+-----------+--------+ 
Fetched 9 row(s) in 0.51s

Anda dapat menyusun record dalam tabel dalam urutan menaik dari id mereka dan membatasi jumlah record menjadi 4, menggunakan limit dan order by klausul seperti yang ditunjukkan di bawah ini.

Query: select * from customers order by id limit 4 
+----+----------+-----+-----------+--------+ 
| 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  | 
+----+----------+-----+-----------+--------+ 
Fetched 4 row(s) in 0.64s

Berikut adalah contoh dari offsetayat. Di sini, kami mendapatkan catatan dicustomerstabel dalam urutan id mereka dan mencetak empat baris pertama mulai dari baris ke- 0 .

[quickstart.cloudera:21000] > select * from customers order by id limit 4 offset 0;

Saat menjalankan, kueri di atas memberikan hasil sebagai berikut.

Query: select * from customers order by id limit 4 offset 0 
+----+----------+-----+-----------+--------+
| 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  | 
+----+----------+-----+-----------+--------+ 
Fetched 4 row(s) in 0.62s

Dengan cara yang sama, Anda bisa mendapatkan empat rekaman dari customers tabel dimulai dari baris yang memiliki offset 5 seperti yang ditunjukkan di bawah ini.

[quickstart.cloudera:21000] > select * from customers order by id limit 4 offset 5; 
Query: select * from customers order by id limit 4 offset 5 
+----+--------+-----+----------+--------+ 
| id | name   | age | address  | salary | 
+----+--------+-----+----------+--------+ 
| 6  | Komal  | 22  | MP       | 32000  | 
| 7  | ram    | 25  | chennai  | 23000  | 
| 8  | ram    | 22  | vizag    | 31000  |
| 9  | robert | 23  | banglore | 28000  | 
+----+--------+-----+----------+--------+ 
Fetched 4 row(s) in 0.52s