Vista CONSTRAINT_COLUMN_USAGE

La vista CONSTRAINT_COLUMN_USAGE contiene todas las columnas que usan las restricciones. Para las restricciones PRIMARY KEY, estas son las columnas de la vista KEY_COLUMN_USAGE. En las restricciones FOREIGN KEY, estas son las columnas de las tablas a las que se hace referencia.

Esquema

La vista INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE tiene el siguiente esquema:

Nombre de la columna Tipo de datos Valor

TABLE_CATALOG

STRING

El nombre del proyecto que contiene el conjunto de datos.

TABLE_SCHEMA

STRING

El nombre del conjunto de datos que contiene la tabla. También se le denomina datasetId.

TABLE_NAME

STRING

El nombre de la tabla. También se le denomina tableId.

COLUMN_NAME

STRING

El nombre de la columna.

CONSTRAINT_CATALOG

STRING

El nombre del proyecto de la restricción.

CONSTRAINT_SCHEMA

STRING

El nombre del conjunto de datos de la restricción.

CONSTRAINT_NAME

STRING

El nombre de la restricción. Puede ser el nombre de la clave primaria si esta usa la columna, o el nombre de la clave externa si una clave externa usa la columna.

Permiso y sintaxis

Las consultas realizadas a esta vista deben tener un calificador de conjunto de datos. Para consultas con un calificador de conjunto de datos, debes tener permisos para el conjunto de datos. Para obtener más información, consulta Sintaxis. En la siguiente tabla, se explican los permisos de la región y los recursos para esta vista:

Nombre de la vista Permiso del recurso Permiso de la región
[PROJECT_ID.]DATASET.INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE; Nivel de conjunto de datos Ubicación del conjunto de datos
Reemplaza lo siguiente:

  • Opcional: PROJECT_ID: el ID del proyecto de Google Cloud. Si no se especifica, se usa el proyecto predeterminado.

Ejemplos

La siguiente consulta muestra las restricciones para una sola tabla en un conjunto de datos:

SELECT *
FROM PROJECT_ID.DATASET.INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE
WHERE table_name = TABLE;

Reemplaza lo siguiente:

  • PROJECT_ID: Opcional El nombre de tu proyecto de la nube. Si no se especifica, este comando usa el proyecto predeterminado.
  • DATASET: nombre del conjunto de datos.
  • TABLE: el nombre de la tabla.

Por otro lado, en la siguiente consulta se muestran las restricciones para todas las tablas de un conjunto de datos único.

SELECT *
FROM PROJECT_ID.DATASET.INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE;

Con las restricciones existentes, los resultados de la consulta son similares a los siguientes:

+-----+---------------------+--------------+------------+-------------+---------------------+-------------------+-------------------------+
| row |    table_catalog    | table_schema | table_name | column_name | constraint_catalog  | constraint_schema |     constraint_name     |
+-----+---------------------+--------------+------------+-------------+---------------------+-------------------+-------------------------+
|   1 | myConstraintCatalog | myDataset    | orders     | o_okey      | myConstraintCatalog | myDataset         | orders.pk$              |
|   2 | myConstraintCatalog | myDataset    | orders     | o_okey      | myConstraintCatalog | myDataset         | lineitem.lineitem_order |
+-----+---------------------+--------------+------------+-------------+---------------------+-------------------+-------------------------+

Si la tabla o el conjunto de datos no tienen restricciones, los resultados de la consulta se verán de la siguiente manera:

+-----------------------------+
| There is no data to display |
+-----------------------------+