Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Untuk mengakses elemen larik, gunakan[]
operator, dengan 1 menentukan elemen pertama, 2 menentukan elemen kedua, dan seterusnya, seperti dalam contoh ini:
WITH dataset AS (
SELECT
ARRAY[CAST(MAP(ARRAY['a1', 'a2', 'a3'], ARRAY[1, 2, 3]) AS JSON)] ||
ARRAY[CAST(MAP(ARRAY['b1', 'b2', 'b3'], ARRAY[4, 5, 6]) AS JSON)]
AS items )
SELECT items[1] AS item FROM dataset
Kueri ini kembali:
+------------------------+
| item |
+------------------------+
| {"a1":1,"a2":2,"a3":3} |
+------------------------+
Untuk mengakses elemen larik pada posisi tertentu (dikenal sebagai posisi indeks), gunakanelement_at()
fungsi dan menentukan nama larik dan posisi indeks:
-
Jika indeks lebih besar dari 0,
element_at()
mengembalikan elemen yang Anda tentukan, menghitung dari awal sampai akhir larik. Berperilaku sebagai[]
Operator. -
Jika indeks kurang dari 0,
element_at()
mengembalikan elemen menghitung dari akhir ke awal larik.
Kueri berikut membuat larikwords
, dan memilih elemen pertamahello
dari itu sebagaifirst_word
, elemen keduaamazon
(menghitung dari akhir larik) sebagaimiddle_word
, dan elemen ketigaathena
, sebagailast_word
.
WITH dataset AS (
SELECT ARRAY ['hello', 'amazon', 'athena'] AS words
)
SELECT
element_at(words, 1) AS first_word,
element_at(words, -2) AS middle_word,
element_at(words, cardinality(words)) AS last_word
FROM dataset
Kueri ini menghasilkan:
+----------------------------------------+
| first_word | middle_word | last_word |
+----------------------------------------+
| hello | amazon | athena |
+----------------------------------------+