KEY_COLUMN_USAGE 檢視畫面
KEY_COLUMN_USAGE
檢視包含 TABLE_CONSTRAINTS
的資料表資料欄,這些資料欄會受 PRIMARY KEY
和 FOREIGN KEY
限制條件限制為鍵。
結構定義
INFORMATION_SCHEMA.KEY_COLUMN_USAGE
檢視表具有下列結構定義:
資料欄名稱 | 資料類型 | 值 |
---|---|---|
|
|
限制專案名稱。 |
|
|
限制資料集名稱。 |
|
|
限制名稱。 |
|
|
受限資料表的專案名稱。 |
|
|
受限資料表資料集的名稱。 |
|
|
受限制資料表的名稱。 |
|
|
受限資料欄的名稱。 |
|
|
限制鍵中資料欄的序數位置 (從 1 開始)。 |
|
|
對於外鍵,則是主鍵限制內的資料欄序數位置 (從 1 開始)。主鍵限制的值為 NULL 。 |
範圍和語法
對這個檢視表執行的查詢必須包含資料集限定詞。如果查詢含有資料集限定詞,您必須具備資料集的權限。詳情請參閱「語法」一節。下表列出這個檢視畫面的區域和資源範圍:
檢視表名稱 | 資源範圍 | 區域範圍 |
---|---|---|
[PROJECT_ID.]DATASET_ID.INFORMATION_SCHEMA.KEY_COLUMN_USAGE; |
資料集層級 | 資料集位置 |
-
選用:
PROJECT_ID
: Google Cloud 專案的 ID。如果未指定,系統會使用預設專案。
如果查詢含有資料集限定詞,您必須具備該資料集的權限。如果查詢包含區域限定條件,您必須具備專案權限。
範例
範例 1:
以下查詢會顯示資料集中單一資料表的限制:
SELECT * FROM PROJECT_ID.DATASET.INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE table_name = TABLE;
更改下列內容:
PROJECT_ID
:選用。雲端專案的名稱。如果未指定,這個指令會使用預設專案。DATASET
:資料集名稱。TABLE
:資料表名稱。
相反地,以下查詢會顯示單一資料集中所有資料表的關鍵欄使用情形。
SELECT * FROM PROJECT_ID.DATASET.INFORMATION_SCHEMA.KEY_COLUMN_USAGE;
如果資料表或資料集沒有限制條件,查詢結果會如下所示:
+-----------------------------+ | There is no data to display | +-----------------------------+
範例 2:
以下 DDL 陳述式會建立主鍵資料表和外鍵資料表。
CREATE TABLE composite_pk (x int64, y string, primary key (x, y) NOT ENFORCED);
CREATE TABLE table composite_fk (x int64, y string, z string, primary key (x, y) NOT ENFORCED, CONSTRAINT composite_fk foreign key (z, x) REFERENCES composite_pk (y, x) NOT ENFORCED);
如果使用範例 1中的陳述式進行查詢,查詢結果會類似下列內容。請注意,CONSTRAINT_CATALOG
、CONSTRAINT_SCHEMA
和重複的資料欄不會包含在示例結果中。
+---------------------------+--------------+-------------+------------------+-------------------------------+ | CONSTRAINT_NAME | TABLE_NAME | COLUMN_NAME | ORDINAL_POSITION | POSITION_IN_UNIQUE_CONSTRAINT | +---------------------------+--------------+-------------+------------------+-------------------------------+ | composite_pk.pk$ | composite_pk | x | 1 | NULL | | composite_pk.pk$ | composite_pk | y | 2 | NULL | | composite_fk.pk$ | composite_fk | x | 1 | NULL | | composite_fk.pk$ | composite_fk | y | 2 | NULL | | composite_fk.composite_fk | composite_fk | z | 1 | 2 | | composite_fk.composite_fk | composite_fk | x | 2 | 1 | +---------------------------+--------------+-------------+------------------+-------------------------------+