Halaman ini menjelaskan cara membuat dan mengelola tampilan Spanner untuk database dialek GoogleSQL dan database dialek PostgreSQL. Untuk mengetahui informasi selengkapnya tentang tabel virtual Spanner, lihat Ringkasan tabel virtual.
Izin
Untuk membuat, memberikan, dan mencabut akses ke tampilan, Anda harus memiliki izin
spanner.database.updateDdl.
Membuat tampilan
Untuk membuat tampilan, gunakan pernyataan DDL
CREATE VIEW untuk memberi nama
tampilan dan memberikan kueri yang menentukannya. Pernyataan ini memiliki dua bentuk:
CREATE VIEWmenentukan tampilan baru dalam database saat ini. Jika tampilan bernamaview_namesudah ada, pernyataanCREATE VIEWakan gagal.CREATE OR REPLACE VIEWmenentukan tampilan baru dalam database saat ini. Jika tampilan bernamaview_namesudah ada, definisinya akan diganti.
Sintaksis untuk pernyataan CREATE VIEW adalah:
{CREATE | CREATE OR REPLACE } VIEW view_name SQL SECURITY { INVOKER | DEFINER } AS query
Karena tampilan adalah tabel virtual, query yang Anda tentukan harus memberikan nama untuk semua kolom dalam tabel virtual tersebut.
Selain itu, Spanner memeriksa query yang Anda tentukan menggunakan resolusi nama ketat, yang berarti semua nama objek skema yang digunakan dalam kueri harus memenuhi syarat sehingga mengidentifikasi satu objek skema secara jelas. Misalnya, dalam contoh berikut, kolom SingerId
dalam tabel Singers harus memenuhi syarat sebagai Singers.SingerId.
Anda harus menentukan SQL SECURITY sebagai INVOKER atau DEFINER dalam pernyataan
CREATE VIEW atau CREATE OR REPLACE VIEW. Untuk mengetahui informasi selengkapnya tentang perbedaan antara kedua jenis keamanan tersebut, lihat Ringkasan tampilan.
Misalnya, asumsikan tabel Singers ditentukan seperti yang ditunjukkan berikut:
GoogleSQL
CREATE TABLE Singers ( SingerId INT64 NOT NULL, FirstName STRING(1024), LastName STRING(1024), SingerInfo BYTES(MAX) ) PRIMARY KEY (SingerId);
PostgreSQL
CREATE TABLE Singers ( SingerId BIGINT PRIMARY KEY, FirstName VARCHAR(1024), LastName VARCHAR(1024), SingerInfo BYTEA );
Anda dapat menentukan tampilan SingerNames dengan hak pemanggil seperti yang ditunjukkan di
bawah ini:
CREATE VIEW SingerNames SQL SECURITY INVOKER AS SELECT Singers.SingerId AS SingerId, Singers.FirstName || ' ' || Singers.LastName AS Name FROM Singers;
Tabel virtual yang dibuat saat tampilan SingerNames digunakan dalam kueri memiliki dua
kolom, SingerId dan Name.
Meskipun valid, definisi tampilan SingerNames ini tidak mematuhi praktik terbaik untuk melakukan transmisi jenis data guna memastikan stabilitas di seluruh perubahan skema, seperti yang dijelaskan di bagian berikutnya.
Praktik terbaik saat membuat tampilan
Untuk meminimalkan kebutuhan untuk memperbarui definisi tampilan, secara eksplisit lakukan transmisi jenis data semua kolom tabel dalam kueri yang menentukan tampilan. Jika Anda melakukannya, definisi tampilan dapat tetap valid di seluruh perubahan skema pada jenis kolom.
Misalnya, definisi tampilan SingerNames berikut mungkin menjadi
tidak valid sebagai akibat dari perubahan jenis data kolom dalam tabel Singers.
CREATE VIEW SingerNames SQL SECURITY INVOKER AS SELECT Singers.SingerId AS SingerId, Singers.FirstName || ' ' || Singers.LastName AS Name FROM Singers;
Anda dapat menghindari tampilan menjadi tidak valid dengan secara eksplisit mentransmisikan kolom ke jenis data yang diperlukan, seperti yang ditunjukkan dalam contoh berikut:
GoogleSQL
CREATE OR REPLACE VIEW SingerNames SQL SECURITY INVOKER AS SELECT CAST(Singers.SingerId AS INT64) AS SingerId, CAST(Singers.FirstName AS STRING) || " " || CAST(Singers.LastName AS STRING) AS Name FROM Singers;
PostgreSQL
CREATE OR REPLACE VIEW SingerNames SQL SECURITY INVOKER AS SELECT CAST(Singers.SingerId AS bigint) AS SingerId, CAST(Singers.FirstName AS varchar) || ' ' || CAST(Singers.LastName AS varchar) AS Name FROM Singers;
Memberikan dan mencabut akses ke tampilan
Sebagai pengguna kontrol akses terperinci, Anda harus memiliki hak istimewa SELECT pada
tampilan. Untuk memberikan hak istimewa SELECT pada tampilan ke peran database:
GoogleSQL
GRANT SELECT ON VIEW SingerNames TO ROLE Analyst;
PostgreSQL
GRANT SELECT ON TABLE SingerNames TO Analyst;
Untuk mencabut hak istimewa SELECT pada tampilan dari peran database:
GoogleSQL
REVOKE SELECT ON VIEW SingerNames FROM ROLE Analyst;
PostgreSQL
REVOKE SELECT ON TABLE SingerNames FROM Analyst;
Membuat kueri tampilan
Cara membuat kueri hak pemanggil atau hak penentu tampilan sama. Namun, bergantung pada jenis keamanan tampilan, Spanner mungkin perlu atau tidak perlu memeriksa objek skema yang dirujuk dalam tampilan terhadap peran database pokok yang memanggil kueri.
Membuat kueri tampilan hak pemanggil
Jika tampilan memiliki hak pemanggil, pengguna harus memiliki hak istimewa pada semua objek skema pokok tampilan untuk membuat kueri.
Misalnya, jika peran database memiliki akses ke semua objek yang dirujuk oleh tampilan
SingerNames, mereka dapat membuat kueri tampilan SingerNames:
SELECT COUNT(SingerID) as SingerCount FROM SingerNames;
Membuat kueri tampilan hak penentu
Jika tampilan memiliki hak penentu, pengguna dapat membuat kueri tampilan tanpa memerlukan
hak istimewa pada objek pokok selama Anda memberikan hak istimewa
SELECT pada tampilan kepada peran yang diperlukan.
Dalam contoh berikut, pengguna dengan peran database Analis ingin membuat kueri
tampilan SingerNames. Namun, pengguna ditolak aksesnya karena SingerNames
adalah tampilan hak pemanggil dan peran Analis tidak memiliki akses ke semua
objek pokok. Dalam hal ini, jika Anda memutuskan untuk memberi Analis akses ke tampilan, tetapi tidak ingin memberi mereka akses ke tabel Singers, Anda dapat mengganti jenis keamanan tampilan ke hak penentu. Setelah Anda mengganti jenis keamanan tampilan, berikan akses peran
Analis ke tampilan. Pengguna kini dapat membuat kueri tabel virtual SingerNames meskipun tidak memiliki akses ke tabel Singers.
SELECT COUNT(SingerID) as SingerCount FROM SingerNames;
Mengganti tampilan
Anda dapat mengganti tampilan menggunakan pernyataan CREATE OR REPLACE VIEW untuk mengubah
definisi tampilan atau jenis keamanan tampilan.
Mengganti tampilan mirip dengan menghapus dan membuat ulang tampilan. Setiap pemberian akses yang diberikan ke tampilan awal harus diberikan lagi setelah mengganti tampilan.
Untuk mengganti tampilan hak invoker dengan tampilan hak penentu:
CREATE OR REPLACE VIEW SingerNames SQL SECURITY DEFINER AS SELECT Singers.SingerId AS SingerId, Singers.FirstName || ' ' || Singers.LastName AS Name FROM Singers;
Menghapus tampilan
Setelah tampilan dihapus, peran database dengan hak istimewa di tampilan tersebut tidak lagi memiliki akses. Untuk menghapus tampilan, gunakan pernyataan DROP VIEW.
DROP VIEW SingerNames;
Mendapatkan informasi tentang tampilan
Anda bisa mendapatkan informasi tentang tampilan dalam database dengan membuat kueri tabel dalam skema INFORMATION_SCHEMA-nya.
Tabel
INFORMATION_SCHEMA.TABLESmenyediakan nama semua tampilan yang ditentukan.Tabel
INFORMATION_SCHEMA.VIEWSmemberikan nama, definisi tampilan, jenis keamanan, dan teks kueri dari semua tampilan yang ditentukan. Pengguna FGAC yang memiliki hak istimewaSELECTpada tampilan dapat memperoleh informasi tentang tampilan dari tabelINFORMATION_SCHEMA.VIEWS. Pengguna FGAC lain memerlukan peranspanner_info_readerjika mereka tidak memiliki hak istimewaSELECTuntuk tampilan.
Untuk memeriksa definisi tampilan dan jenis keamanan tampilan yang disebut
ProductSoldLastWeek:
SELECT * FROM INFORMATION_SCHEMA.VIEWS WHERE TABLE_NAME = 'ProductSoldLastWeek';