Tentang pernyataan
Pernyataan adalah kueri pengujian kualitas data yang menemukan baris yang melanggar satu atau beberapa kondisi yang ditentukan dalam kueri. Jika kueri menampilkan baris apa pun, pernyataan akan gagal. Dataform menjalankan pernyataan setiap kali memperbarui alur kerja SQL Anda dan memberi tahu Anda jika ada pernyataan yang gagal.
Dataform secara otomatis membuat tampilan di BigQuery yang berisi hasil kueri pernyataan yang dikompilasi. Seperti yang dikonfigurasi dalam file setelan alur kerja, Dataform membuat tampilan ini dalam skema pernyataan tempat Anda dapat memeriksa hasil pernyataan.
Misalnya, untuk skema dataform_assertions
default, Dataform
akan membuat tampilan di BigQuery dalam format berikut:
dataform_assertions.assertion_name
.
Anda dapat membuat pernyataan untuk semua jenis tabel Dataform: tabel, tabel inkremental, tampilan, dan tampilan terwujud.
Anda dapat membuat pernyataan dengan cara berikut:
Menambahkan pernyataan bawaan ke blok konfigurasi tabel.
Anda dapat menambahkan pernyataan bawaan ke blok
config
tabel dan menentukan kondisinya.Menambahkan pernyataan manual dalam file SQLX terpisah.
Anda menulis pernyataan kustom secara manual dalam file SQLX terpisah untuk kasus penggunaan lanjutan atau untuk set data yang tidak dibuat oleh Dataform.
Sebelum memulai
Di konsol Google Cloud , buka halaman Dataform.
Pilih atau buat repositori.
Pilih atau buat ruang kerja pengembangan.
Peran yang diperlukan
Untuk mendapatkan izin yang diperlukan guna membuat pernyataan,
minta administrator untuk memberi Anda
peran IAM Dataform Editor (roles/dataform.editor
) di ruang kerja.
Untuk mengetahui informasi selengkapnya tentang cara memberikan peran, lihat Mengelola akses ke project, folder, dan organisasi.
Anda mungkin juga bisa mendapatkan izin yang diperlukan melalui peran khusus atau peran bawaan lainnya.
Membuat pernyataan bawaan
Anda dapat menambahkan pernyataan Dataform bawaan ke blok config
tabel. Dataform menjalankan pernyataan ini setelah pembuatan tabel. Setelah
Dataform membuat tabel, Anda dapat melihat apakah pernyataan diteruskan di tab
Log eksekusi alur kerja di ruang kerja Anda.
Anda dapat membuat pernyataan berikut di blok config
tabel:
nonNull
Kondisi ini menyatakan bahwa kolom yang ditentukan bukan null di semua baris tabel. Kondisi ini digunakan untuk kolom yang tidak boleh bernilai null.
Contoh kode berikut menunjukkan pernyataan
nonNull
dalam blokconfig
tabel:
config {
type: "table",
assertions: {
nonNull: ["user_id", "customer_id", "email"]
}
}
SELECT ...
rowConditions
Kondisi ini menyatakan bahwa semua baris tabel mengikuti logika kustom yang Anda tentukan. Setiap kondisi baris adalah ekspresi SQL kustom, dan setiap baris tabel dievaluasi berdasarkan setiap kondisi baris. Pernyataan akan gagal jika baris tabel menghasilkan
false
.Contoh kode berikut menunjukkan pernyataan
rowConditions
kustom dalam blokconfig
tabel inkremental:
config {
type: "incremental",
assertions: {
rowConditions: [
'signup_date is null or signup_date > "2022-08-01"',
'email like "%@%.%"'
]
}
}
SELECT ...
uniqueKey
Kondisi ini menyatakan bahwa, dalam kolom yang ditentukan, tidak ada baris tabel yang memiliki nilai yang sama.
Contoh kode berikut menunjukkan pernyataan
uniqueKey
dalam blokconfig
tampilan:
config {
type: "view",
assertions: {
uniqueKey: ["user_id"]
}
}
SELECT ...
uniqueKeys
Kondisi ini menyatakan bahwa, di kolom yang ditentukan, tidak ada baris tabel yang memiliki nilai yang sama. Pernyataan gagal jika ada lebih dari satu baris dalam tabel dengan nilai yang sama untuk semua kolom yang ditentukan.
Contoh kode berikut menunjukkan pernyataan
uniqueKeys
dalam blokconfig
tabel:
config {
type: "table",
assertions: {
uniqueKeys: [["user_id"], ["signup_date", "customer_id"]]
}
}
SELECT ...
Menambahkan pernyataan ke blok config
Untuk menambahkan pernyataan ke blok konfigurasi tabel, ikuti langkah-langkah berikut:
- Di ruang kerja pengembangan, di panel Files, pilih file SQLX definisi tabel.
- Di blok
config
file tabel, masukkanassertions: {}
. - Di dalam
assertions: {}
, tambahkan pernyataan Anda. - Opsional: Klik Format.
Contoh kode berikut menunjukkan kondisi yang ditambahkan di blok config
:
config {
type: "table",
assertions: {
uniqueKey: ["user_id"],
nonNull: ["user_id", "customer_id"],
rowConditions: [
'signup_date is null or signup_date > "2019-01-01"',
'email like "%@%.%"'
]
}
}
SELECT ...
Membuat pernyataan manual dengan SQLX
Pernyataan manual adalah kueri SQL yang Anda tulis dalam file SQLX khusus. Kueri SQL pernyataan manual harus menampilkan nol baris. Jika kueri menampilkan baris saat dijalankan, pernyataan akan gagal.
Untuk menambahkan pernyataan manual dalam file SQLX baru, ikuti langkah-langkah berikut:
- Di panel Files, di samping
definitions/
, klik menu More. - Klik Create file.
Di kolom Add a file path, masukkan nama file, diikuti dengan
.sqlx
. Misalnya,definitions/custom_assertion.sqlx
.Nama file hanya boleh berisi angka, huruf, tanda hubung, dan garis bawah.
Klik Create file.
Di panel File, klik file baru.
Dalam file tersebut, masukkan:
config { type: "assertion" }
Di bawah blok
config
, tulis kueri SQL atau beberapa kueri.Opsional: Klik Format.
Contoh kode berikut menunjukkan pernyataan manual dalam file SQLX yang menyatakan
bahwa kolom A, B, dan c
tidak pernah NULL
di sometable
:
config { type: "assertion" }
SELECT
*
FROM
${ref("sometable")}
WHERE
a IS NULL
OR b IS NULL
OR c IS NULL
Menetapkan pernyataan sebagai dependensi
Jika tindakan alur kerja B bergantung pada tindakan alur kerja A yang memiliki pernyataan, kegagalan pernyataan tindakan A tidak akan memblokir Dataform dari mengeksekusi tindakan B. Untuk mengeksekusi tindakan B hanya jika pernyataan tindakan A lulus, Anda harus menetapkan pernyataan tindakan A sebagai dependensi tindakan B.
Anda dapat menetapkan pernyataan sebagai dependensi tindakan yang dipilih dengan cara berikut:
- Menetapkan pernyataan yang dipilih sebagai dependensi
Anda dapat menetapkan pernyataan yang dipilih secara manual sebagai dependensi dengan menambahkannya ke
dependencies: [ "" ]
di blokconfig
dari tindakan yang diedit.Misalnya, jika tindakan B bergantung pada tindakan A, dan Anda ingin tindakan B hanya bergantung pada pernyataan yang dipilih dari tindakan A, Anda dapat menambahkan pernyataan yang dipilih tersebut ke blok
config
tindakan B.Anda dapat menetapkan pernyataan yang dipilih secara manual sebagai dependensi untuk semua jenis tindakan, kecuali deklarasi sumber data.
- Menetapkan pernyataan tindakan dependensi yang dipilih sebagai dependensi
Anda dapat menetapkan parameter
includeDependentAssertions
untuk secara otomatis menetapkan semua pernyataan langsung tindakan alur kerja dependensi yang dipilih sebagai dependensi tindakan yang diedit. Dataform menambahkan pernyataan ini sebagai dependensi selama setiap kompilasi tindakan untuk memastikan bahwa dependensi telah diperbarui jika pernyataan tindakan dependensi berubah.Misalnya, jika tindakan C bergantung pada tindakan A dan B, tetapi Anda hanya ingin tindakan C bergantung pada pernyataan tindakan A, Anda dapat mengedit tindakan C dan menetapkan parameter
includeDependentAssertions
untuk menetapkan semua pernyataan tindakan A secara otomatis sebagai dependensi tindakan C.Anda dapat menetapkan parameter
includeDependentAssertions
untuk tindakan dari jenis berikut:table
view
operations
- Menetapkan pernyataan semua tindakan dependensi sebagai dependensi
Anda dapat menetapkan parameter
dependOnDependencyAssertions
untuk menetapkan semua pernyataan langsung dari semua tindakan dependensi tindakan yang diedit secara otomatis sebagai dependensi tambahan tindakan yang diedit. Dataform menambahkan pernyataan ini sebagai dependensi selama setiap kompilasi tindakan untuk memastikan bahwa dependensi telah diperbarui jika pernyataan tindakan dependensi berubah.Misalnya, jika tindakan C bergantung pada tindakan A dan B, Anda dapat mengedit tindakan C dan menetapkan parameter
dependOnDependencyAssertions
untuk menetapkan semua pernyataan tindakan A dan B secara otomatis sebagai dependensi tindakan C.Anda dapat menetapkan parameter
dependOnDependencyAssertions
untuk tindakan dari jenis berikut:table
view
operations
Saat Anda menetapkan parameter dependOnDependencyAssertions
dan
parameter includeDependentAssertions
dalam satu file,
parameter includeDependentAssertions
akan diprioritaskan.
Misalnya, jika Anda menetapkan dependOnDependencyAssertions
ke true
,
tetapi juga menetapkan includeDependentAssertions
ke false
untuk tindakan dependensi
yang dipilih, Dataform tidak akan menambahkan pernyataan tindakan tersebut ke dependensi.
Contoh kode berikut menunjukkan parameter dependOnDependencyAssertions
dan
includeDependentAssertions
yang ditetapkan dalam file definisi tabel yang sama:
// filename is tableName.sqlx
config {
type: "table",
dependOnDependencyAssertions: true,
dependencies: [ "actionA", {name: "actionB", includeDependentAssertions: false} ]
}
SELECT * FROM ${ref("actionC")}
Pada contoh kode sebelumnya, Dataform menambahkan semua pernyataan langsung
actionA
dan actionC
ke dependensi tableName
selama kompilasi.
Menetapkan pernyataan yang dipilih sebagai dependensi
Untuk menjalankan tindakan alur kerja hanya jika pernyataan yang dipilih lulus,
Anda dapat menambahkan pernyataan yang dipilih ke dependencies: [ "" ]
di blok config
dari tindakan yang diedit.
Untuk menetapkan pernyataan yang dipilih sebagai dependensi tindakan alur kerja yang dipilih, ikuti langkah-langkah berikut:
- Di ruang kerja pengembangan, di panel Files, luaskan
definitions/
. - Pilih file SQLX tindakan alur kerja.
- Di blok
config
file tindakan, masukkandependencies: [ "" ]
. Di dalam
dependencies: [ "" ]
, masukkan nama pernyataan tindakan atau nama file pernyataan manual yang ingin Anda tetapkan sebagai dependensi dalam salah satu format berikut:nonNull
config { type: "ACTION_TYPE", dependencies: [ "ACTION_DATASET_NAME_ACTION_NAME_assertions_nonNull"] }
Ganti kode berikut:
- ACTION_TYPE: jenis tindakan alur kerja:
table
,view
, atauoperations
. - ACTION_DATASET_NAME: nama set data tempat tindakan ditentukan. Set data default ditentukan dalam file setelan alur kerja.
- ACTION_NAME: nama tindakan tempat pernyataan ditentukan.
rowConditions
config { type: "ACTION_TYPE", dependencies: [ "ACTION_DATASET_NAME_ACTION_NAME_assertions_rowConditions"] }
Ganti kode berikut:
- ACTION_TYPE: jenis tindakan alur kerja:
table
,view
, atauoperations
. - DATASET_NAME: nama set data tempat tindakan ditentukan. Set data default ditentukan dalam file setelan alur kerja.
- ACTION_NAME: nama tindakan tempat pernyataan ditentukan.
uniqueKey
config { type: "ACTION_TYPE", dependencies: [ "ACTION_DATASET_NAME_ACTION_NAME_assertions_uniqueKey_INDEX"] }
Ganti kode berikut:
- ACTION_TYPE: jenis tindakan alur kerja:
table
,view
, atauoperations
. - DATASET_NAME: nama set data tempat tabel ditentukan. Set data default ditentukan dalam file setelan alur kerja.
- ACTION_NAME: nama tabel tempat pernyataan ditentukan.
- INDEX: indeks array kunci yang ditentukan dalam
pernyataan
uniqueKey
yang ingin Anda tambahkan sebagai dependensi. Misalnya,0
atau1
. Jika hanya satu array kunci yang ditentukan dalam pernyataan, indeksnya adalah0
.
uniqueKeys
config { type: "ACTION_TYPE", dependencies: [ "ACTION_DATASET_NAME_ACTION_NAME_assertions_uniqueKeys_INDEX"] }
Ganti kode berikut:
- ACTION_TYPE: jenis tindakan alur kerja:
table
,view
, atauoperations
. - DATASET_NAME: nama set data tempat tabel ditentukan. Set data default ditentukan dalam file setelan alur kerja.
- ACTION_NAME: nama tabel tempat pernyataan ditentukan.
- INDEX: indeks array kunci yang ditentukan dalam
pernyataan
uniqueKeys
yang ingin Anda tambahkan sebagai dependensi—misalnya,0
atau1
. Jika hanya satu array kunci yang ditentukan dalam pernyataan, indeksnya adalah0
.
pernyataan manual
config { type: "ACTION_TYPE", dependencies: [ "MANUAL_ASSERTION_NAME"] }
Ganti kode berikut:
- ACTION_TYPE: jenis tindakan alur kerja:
table
,view
, atauoperations
. - MANUAL_ASSERTION_NAME nama pernyataan manual.
- ACTION_TYPE: jenis tindakan alur kerja:
Untuk menambahkan pernyataan lain sebagai dependensi ke tabel yang diedit, ulangi Langkah 4.
Opsional: Klik Format.
Contoh kode berikut menunjukkan pernyataan yang ditambahkan ke tabel A,
yang ditentukan dalam set data dataform
:
config {
type: "table",
assertions: {
uniqueKey: ["user_id"],
nonNull: ["user_id", "customer_id"],
}
}
Contoh kode berikut menunjukkan pernyataan tabel A yang ditambahkan sebagai dependensi ke tabel B:
config {
type: "table",
dependencies: [ "dataform_A_assertions_uniqueKey_0", "dataform_A_assertions_nonNull"]
}
Contoh kode berikut menunjukkan pernyataan manual yang ditentukan dalam
file manualAssertion.sqlx
, yang ditambahkan sebagai dependensi ke tampilan:
config {
type: "view",
dependencies: [ "manualAssertion"]
}
Contoh kode berikut menunjukkan file manual_assertion
dan
pernyataan tabel sometable
yang ditambahkan sebagai dependensi ke tabel:
config {
type: "table",
dependencies: [ "manual_assertion", "dataform_sometable_assertions_nonNull" , "dataform_sometable_assertions_rowConditions"]
}
SELECT * FROM ${ref("referenced_table")} LEFT JOIN ...
Menetapkan pernyataan tindakan yang dipilih sebagai dependensi
Untuk mengeksekusi tindakan alur kerja hanya jika semua pernyataan langsung
tindakan dependensi yang dipilih lulus,
tetapkan parameter includeDependentAssertions
ke true
dalam tindakan yang diedit.
Dataform secara otomatis menambahkan pernyataan langsung tindakan dependensi
yang dipilih ke dependensi selama kompilasi. Nilai defaultnya adalah false
.
Untuk menetapkan semua pernyataan tindakan dependensi yang dipilih sebagai dependensi, ikuti langkah-langkah berikut:
- Di ruang kerja pengembangan, di panel Files, luaskan
definitions/
. - Pilih file SQLX tindakan alur kerja.
Dalam file, tetapkan parameter
includeDependentAssertions
ketrue
dengan salah satu cara berikut:Di blok
config
config { type: "ACTION_TYPE", dependencies: [{name: "dEPENDENCY_ACTION_NAME", includeDependentAssertions: true}] }
Ganti kode berikut:
- ACTION_TYPE: jenis tindakan alur kerja:
table
,view
, atauoperations
. - DEPENDENCY_ACTION_NAME: nama tindakan dependensi yang pernyataannya ingin Anda tetapkan sebagai dependensi tindakan yang diedit.
Dalam pernyataan
SELECT
config { type: "ACTION_TYPE" } SELECT * FROM ${ref({name: "DEPENDENCY_ACTION_NAME", includeDependentAssertions: true})}
Ganti kode berikut:
- ACTION_TYPE: jenis tindakan alur kerja:
table
,view
, atauoperations
. - DEPENDENCY_ACTION_NAME: nama tindakan dependensi yang pernyataannya ingin Anda tetapkan sebagai dependensi tindakan yang diedit.
- ACTION_TYPE: jenis tindakan alur kerja:
Opsional: Klik Format.
Contoh kode berikut menunjukkan tableC
yang bergantung pada viewA
, tableB
,
dan semua pernyataan tableB
:
// filename is tableC.sqlx
config {
type: "table",
dependencies: ["viewA", {name: "tableB", includeDependentAssertions: true}]
}
SELECT * FROM ...
Dalam contoh kode sebelumnya, Dataform otomatis menambahkan semua
pernyataan langsung tableB
sebagai dependensi ke tableC
selama kompilasi.
Menetapkan pernyataan semua tindakan dependensi sebagai dependensi
Untuk mengeksekusi tindakan alur kerja hanya jika semua pernyataan langsung
dari semua tindakan dependensi lulus,
tetapkan parameter dependOnDependencyAssertions
ke true
dalam tindakan yang diedit.
Dataform secara otomatis menambahkan pernyataan langsung tindakan dependensi sebagai dependensi selama kompilasi. Nilai defaultnya adalah false
.
Saat Anda menetapkan parameter dependOnDependencyAssertions
dan
parameter includeDependentAssertions
dalam satu file,
parameter includeDependentAssertions
akan diprioritaskan untuk tindakan
dependensi yang ditetapkan.
Untuk menetapkan semua pernyataan tindakan dependensi yang dipilih sebagai dependensi, ikuti langkah-langkah berikut:
- Di ruang kerja pengembangan, di panel Files, luaskan
definitions/
. - Pilih file SQLX tindakan alur kerja.
Dalam file, tetapkan parameter
dependOnDependencyAssertions
ketrue
dalam format berikut:config { type: "ACTION_TYPE", dependOnDependencyAssertions: true, dependencies: [ "dependency1", "dependency2" ] }
Ganti ACTION_TYPE: jenis tindakan alur kerja. Nilai yang didukung mencakup
table
,view
, danoperations
.Opsional: Klik Format.
Contoh kode berikut menunjukkan sometableE
yang bergantung pada sometableA
,
sometabletableB
, sometableC
, dan sometableD
serta semua pernyataan langsung
tabel dependensi:
// filename is sometableE.sqlx
config {
type: "table",
dependOnDependencyAssertions: true,
dependencies: [ "sometableA", "sometableB" ]
}
SELECT * FROM ${ref("sometableC")}
SELECT * FROM ${ref("sometableD")}
Dalam contoh kode sebelumnya, Dataform otomatis menambahkan semua
pernyataan langsung sometableA
, sometableB
, sometableC
, dan sometableD
sebagai dependensi ke sometableE
selama kompilasi.
Langkah selanjutnya
- Untuk mempelajari jenis pernyataan lebih lanjut, lihat Dataform API.
- Untuk mempelajari cara menentukan pernyataan dengan JavaScript, lihat Membuat alur kerja SQL dengan JavaScript.
- Untuk mempelajari cara menjalankan alur kerja secara manual, lihat Memicu eksekusi.