Struktur Kueri

Kueri untuk kolom resource, segmen, dan metrik dapat dikirim ke metode GoogleAdsService Search atau SearchStream. Untuk membuat kueri di Bahasa Kueri Google Ads, Anda harus membuatnya menggunakan tata bahasa. Kueri terdiri dari sejumlah klausa:

  • SELECT
  • FROM
  • WHERE
  • ORDER BY
  • LIMIT
  • PARAMETERS

Klausul menggunakan nama kolom, nama resource, operator, kondisi, dan pengurutan untuk membantu Anda memilih data yang benar. Jika digabungkan menjadi satu kueri, permintaan dapat dibuat menggunakan Google Ads API.

Klausul

Video: Kompatibilitas Kolom GAQL

PILIH

Klausul SELECT menentukan sekumpulan kolom yang akan diambil dalam permintaan. SELECT menggunakan daftar kolom resource, kolom segmen, dan metrik yang dipisahkan koma, yang menampilkan nilai dalam respons. Klausa SELECT wajib ada dalam kueri.

Contoh kueri di bawah menunjukkan contoh pemilihan atribut untuk resource tertentu:

SELECT
  campaign.id,
  campaign.name
FROM campaign

Anda dapat meminta berbagai jenis kolom dalam satu permintaan, misalnya:

SELECT
  campaign.id,
  campaign.name,
  bidding_strategy.id,
  bidding_strategy.name,
  segments.device,
  segments.date,
  metrics.impressions,
  metrics.clicks
FROM campaign
WHERE segments.date DURING LAST_30_DAYS
  • Kolom sumber daya

    • campaign.id
    • campaign.name
  • Kolom sumber daya

    • bidding_strategy.id
    • bidding_strategy.name
  • Kolom segmen

    • segments.device
    • segments.date
  • Metrik

    • metrics.impressions
    • metrics.clicks

Beberapa kolom mungkin tidak diizinkan dalam klausul SELECT, karena batasan berikut:

  • Mengirim kueri ke kolom yang tidak dapat dipilih. Kolom ini akan memiliki atribut metadata Selectable yang ditandai sebagai false.
  • Memilih atribut kolom berulang. Kolom ini akan memiliki atribut metadata isRepeated yang ditandai sebagai true.
  • Memilih kolom yang tidak tersedia untuk resource tertentu dalam klausa FROM. Atribut beberapa resource tidak dapat dipilih bersamaan, dan hanya subset dari semua metrik dan segmen yang akan tersedia untuk resource dalam klausa FROM.
  • Memilih segmen atau metrik yang tidak kompatibel satu sama lain. Untuk mengetahui informasi selengkapnya tentang hal ini, lihat bagian segmentasi.

Informasi terkait kondisi di atas dapat ditemukan di dokumen referensi kami atau dari GoogleAdsFieldService.

FROM

Klausul FROM menentukan resource utama yang akan ditampilkan. Resource dalam klausa FROM menentukan kolom yang dapat digunakan semua klausa lainnya untuk kueri tertentu. Hanya satu resource yang dapat ditentukan dalam klausa FROM. Klausul FROM wajib ada dalam kueri ke metode GoogleAdsService Search atau SearchStream. Namun, klausa FROM tidak boleh ditentukan saat menggunakan GoogleAdsFieldService.

Meskipun hanya satu resource yang dapat ada dalam klausa FROM untuk kueri tertentu, kolom dari Resource yang Diatribusikan juga dapat tersedia. Resource ini digabungkan secara implisit dengan resource dalam klausa FROM, jadi Anda hanya perlu menambahkan atributnya ke klausa SELECT untuk menampilkan nilainya. Tidak semua resource memiliki Resource yang Diatribusikan. Dalam contoh berikut, Anda dapat meminta ID grup iklan dan ID kampanye dari grup iklan:

SELECT
  campaign.id,
  ad_group.id
FROM ad_group

Kolom resource_name dari resource utama selalu ditampilkan. Dalam contoh berikut, ad_group.resource_name akan disertakan dalam respons meskipun tidak dipilih secara eksplisit dalam kueri:

SELECT ad_group.id
FROM ad_group

Hal yang sama berlaku untuk resource lain jika setidaknya satu kolom dipilih. Misalnya: campaign.resource_name akan disertakan dalam respons untuk kueri berikut:

SELECT
  campaign.id,
  ad_group.id
FROM ad_group

WHERE

Klausa WHERE menentukan kondisi yang akan diterapkan saat memfilter data untuk permintaan. Saat menggunakan klausa WHERE, satu atau beberapa kondisi dapat ditentukan menggunakan AND untuk memisahkannya. Setiap kondisi harus mengikuti pola field_name Operator value. Klausul WHERE bersifat opsional dalam kueri.

Berikut adalah contoh penggunaan WHERE untuk menampilkan metrik dari jangka waktu tertentu:

SELECT
  campaign.id,
  campaign.name,
  metrics.impressions
FROM campaign
WHERE segments.date DURING LAST_30_DAYS

Anda dapat menggabungkan beberapa kondisi untuk memfilter data. Contoh ini akan meminta jumlah klik untuk semua kampanye dengan tayangan iklan di perangkat seluler dalam 30 hari terakhir.

SELECT
  campaign.id,
  campaign.name,
  segments.device,
  metrics.clicks
FROM campaign
WHERE metrics.impressions > 0
  AND segments.device = MOBILE
  AND segments.date DURING LAST_30_DAYS

Segmen dalam klausa WHERE harus ada dalam klausa SELECT, dengan segmen tanggal berikut, yang disebut sebagai segmen tanggal inti, menjadi pengecualian:

  • segments.date
  • segments.week
  • segments.month
  • segments.quarter
  • segments.year

Dalam kueri berikut, perhatikan bahwa segments.date dipilih. Karena segmen ini adalah segmen tanggal inti, segmen ini memerlukan rentang tanggal terbatas yang terdiri dari segmen tanggal inti dalam klausa WHERE yang akan diberikan.

SELECT
  campaign.id,
  campaign.name,
  segments.date,
  metrics.clicks
FROM campaign
WHERE segments.date DURING LAST_30_DAYS

Semua segmen yang memenuhi kondisi di atas adalah: segments.date, segments.week, segments.month, segments.quarter, dan segments.year. Jika salah satu segmen ini dipilih, setidaknya salah satunya harus digunakan dalam klausa WHERE.

Saat memfilter, kepekaan huruf besar/kecil operator penting untuk diingat. Lihat Sensitivitas huruf besar/kecil untuk mengetahui detail selengkapnya.

Untuk mengetahui daftar lengkap operator, lihat tata bahasa.

ORDER BY

Klausa ORDER BY menentukan urutan hasil yang akan ditampilkan. Dengan begitu, Anda dapat menyusun data dalam urutan menaik atau menurun berdasarkan nama kolom. Setiap pengurutan ditentukan sebagai field_name yang diikuti dengan ASC atau DESC. Jika ASC maupun DESC tidak ditentukan, urutan defaultnya adalah ASC. Klausul ORDER BY bersifat opsional dalam kueri.

Kueri berikut mengurutkan kampanye yang ditampilkan berdasarkan jumlah klik dari tertinggi hingga terendah:

SELECT
  campaign.name,
  metrics.clicks
FROM campaign
ORDER BY metrics.clicks DESC

Anda dapat menentukan beberapa kolom dalam klausa ORDER BY menggunakan daftar yang dipisahkan koma. Pengurutan akan terjadi dalam urutan yang sama seperti yang ditentukan dalam kueri. Misalnya, dalam kueri ini yang memilih data grup iklan, hasilnya akan diurutkan dalam urutan menaik menurut nama kampanye, lalu dalam urutan menurun menurut jumlah tayangan, lalu dalam urutan menurun menurut jumlah klik:

SELECT
  campaign.name,
  ad_group.name,
  metrics.impressions,
  metrics.clicks
FROM ad_group
ORDER BY
  campaign.name,
  metrics.impressions DESC,
  metrics.clicks DESC

LIMIT

Klausa LIMIT memungkinkan Anda menentukan jumlah hasil yang akan ditampilkan. Opsi ini berguna jika Anda hanya tertarik pada ringkasan.

Misalnya, LIMIT dapat digunakan untuk membatasi jumlah total hasil untuk kueri berikut:

SELECT
  campaign.name,
  ad_group.name,
  segments.device,
  metrics.impressions
FROM ad_group
ORDER BY metrics.impressions DESC
LIMIT 50

PARAMETER

Klausa PARAMETERS memungkinkan Anda menentukan parameter meta untuk permintaan. Parameter ini dapat memengaruhi jenis baris yang ditampilkan.

Parameter meta berikut didukung:

include_drafts

Tetapkan include_drafts ke true agar entity draf dapat ditampilkan. Default-nya adalah false.

Misalnya, kueri berikut mengambil draf kampanye bersama dengan kampanye reguler:

SELECT campaign.name
FROM campaign
PARAMETERS include_drafts=true

omit_unselected_resource_names

Tetapkan omit_unselected_resource_names ke true untuk mencegah nama resource setiap jenis resource dalam respons ditampilkan kecuali jika diminta secara eksplisit dalam klausa SELECT. Defaultnya adalah false.

Contoh omit_unselected_resource_names
SELECT
  campaign.name,
  customer.id
FROM campaign
Returned resources:
campaign.resource_name
customer.resource_name

omit_unselected_resource_names secara default adalah false, sehingga semua kolom resource_name ditampilkan.
SELECT
  campaign.name,
  customer.id
FROM campaign
PARAMETERS omit_unselected_resource_names = true
Returned resources:
Tidak ada.
omit_unselected_resource_names ditentukan sebagai true dan campaign.resource_name serta customer.resource_name bukan bagian dari klausa SELECT.
SELECT
  campaign.name,
  campaign.resource_name
FROM campaign
PARAMETERS omit_unselected_resource_names = true
Returned resource:
campaign.resource_name
omit_unselected_resource_names ditentukan sebagai true dan campaign.resource_name diminta sebagai bagian dari klausa SELECT.

Aturan bahasa tambahan

Selain contoh untuk setiap klausa, Bahasa Kueri Google Ads memiliki perilaku berikut yang dapat digunakan:

  • Kolom resource utama tidak harus berada dalam klausa SELECT untuk kueri. Misalnya, Anda mungkin hanya ingin menggunakan satu atau beberapa kolom resource utama untuk memfilter data:

    SELECT campaign.id
    FROM ad_group
    WHERE ad_group.status = PAUSED
    
  • Metrik dapat dipilih secara eksklusif untuk resource tertentu; tidak ada kolom lain dari resource yang diperlukan dalam kueri:

    SELECT
      metrics.impressions,
      metrics.clicks,
      metrics.cost_micros
    FROM campaign
    
  • Kolom segmentasi dapat dipilih tanpa kolom resource atau metrik yang menyertainya:

    SELECT segments.device FROM campaign
    
  • Kolom resource_name (misalnya, campaign.resource_name) dapat digunakan untuk memfilter atau mengurutkan data:

    SELECT
      campaign.id,
      campaign.name
    FROM campaign
    WHERE campaign.resource_name = 'customers/1234567/campaigns/987654'