GoogleSQL 方言数据库的信息架构

信息架构是一个内置架构, Spanner 数据库。您可以对 INFORMATION_SCHEMA 中的表运行 SQL 查询来提取数据库的架构元数据。

例如,以下查询可提取数据库中所有用户定义的表的名称:

  SELECT
    table_name
  FROM
    information_schema.tables
  WHERE
    table_schema = ''

精细的访问权限控制用户会看到部分INFORMATION_SCHEMA的过滤结果 具体取决于其数据库角色有关详情,请参阅关于 精细的访问权限控制

用法

INFORMATION_SCHEMA 表只能通过 SQL 接口使用, 示例:

  • executeQuery API
  • gcloud spanner databases execute-sql 命令
  • Google Cloud 控制台中数据库的 Spanner Studio 页面)

其他单次读取方法不支持 INFORMATION_SCHEMA

一些额外的 INFORMATION_SCHEMA 使用说明:

information_schema 表中的行过滤

拥有数据库级 IAM 权限的主账号,以及具备 已被授予 spanner_info_reader 系统角色(或属于该系统角色的成员) 角色)可以查看所有 information_schema 表中的所有行。对于其他 对于某些表,系统会根据当前的 数据库角色。以下部分中的表和视图说明 指示如何将行过滤应用于每个表和视图。

INFORMATION_SCHEMA 中的表

以下部分介绍了 INFORMATION_SCHEMA 中的表 适用于 GoogleSQL 方言数据库。

SCHEMATA

INFORMATION_SCHEMA.SCHEMATA 表列出了数据库中的架构。这些 包含信息架构和命名架构(其中包含表) 定义。

列名 类型 说明
CATALOG_NAME STRING 目录的名称。此列的存在是为了兼容 SQL 标准信息架构表。此列始终是 空字符串。
SCHEMA_NAME STRING 架构的名称。这是已命名架构的名称,或者是 `` 默认架构
PROTO_BUNDLE STRING 如果数据库包含 proto 软件包语句,此列会提供 有关架构中使用的 proto 软件包的信息。此列为 NULL 如果数据库中不存在任何 proto 软件包。

DATABASE_OPTIONS

此表列出了在数据库上设置的选项。

列名 类型 说明
CATALOG_NAME STRING 目录的名称。始终为空字符串。
SCHEMA_NAME STRING 架构的名称。如果未命名,则为空字符串。
OPTION_NAME STRING 数据库选项的名称。
OPTION_TYPE STRING 数据库选项的数据类型。
OPTION_VALUE STRING 数据库选项值。

PLACEMENTS

此表会列出数据库中的展示位置。

列名 类型 说明
PLACEMENT_NAME STRING 展示位置的名称。
IS_DEFAULT BOOL 指示展示位置是否为默认展示位置的布尔值。

PLACEMENT_OPTIONS

下表列出了针对每个展示位置设置的选项 在 CREATE PLACEMENT 语句的 OPTIONS 子句中。

OPTION_NAME 的有效值包括:

  • instance_partition
  • default_leader
列名 类型 说明
PLACEMENT_NAME STRING 展示位置的名称。
OPTION_NAME STRING 展示位置选项的名称。
OPTION_TYPE STRING 展示位置选项的数据类型。这两个选项都为 STRING(MAX)
OPTION_VALUE STRING 展示位置选项的值。对于instance_partition, 这是实例分区的名称。对于default_leader, 它是默认主要区域的名称。

TABLES

这个按行过滤的表列出了数据库中的表和视图。主账号 拥有数据库级 IAM 权限, 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能查看表 符合以下任一要求:

  • SELECTINSERTUPDATEDELETE精细的访问权限控制 将表的特权授予给当前数据库角色以及需要 当前数据库角色是否为成员或 public
  • SELECTINSERTUPDATE 针对当前数据库角色授予任何表列的权限, 当前数据库角色所属的角色,或者 public
列名 类型 说明
TABLE_CATALOG STRING 未使用。始终为空字符串。
TABLE_SCHEMA STRING 未使用。始终为空字符串。
TABLE_NAME STRING 表、视图或同义词的名称。
TABLE_TYPE STRING 表的类型。对于表,其值为 BASE TABLE;对于视图,其值为 VIEW; 值为 SYNONYM
PARENT_TABLE_NAME STRING 如果此表是交错表,则为父表的名称,以及 否则为 NULL
ON_DELETE_ACTION STRING 该值设置为 CASCADENO ACTION 交错表,否则为 NULL。请参阅 表格 语句
SPANNER_STATE STRING 如果批量创建表,表在创建过程中可能会经历多种状态 操作。例如,在创建表时指定了 外键(需要回填其索引)。可能的状态包括:
  • ADDING_FOREIGN_KEY:添加表的外键。
  • WAITING_FOR_COMMIT:完成架构更改。
  • COMMITTED:创建表的架构更改具有 。在更改生效之前,您无法对该表执行写入操作 投入。
INTERLEAVE_TYPE STRING 指示是否有父子关系的表达式文本 及其交错的表格之间的关系。 可能的值包括:
  • IN:表没有父子表 关系。此表中的某一行可以存在,而不管该行 父表行不存在。
  • IN PARENT:表具有父子关系。 此表中的某一行必须存在其父表行。
  • 空字符串表示此表没有交错 关系。
ROW_DELETION_POLICY_EXPRESSION STRING 定义 行删除政策。 例如 OLDER_THAN(CreatedAt, INTERVAL 1 DAY)OLDER_THAN(ExpiredDate, INTERVAL 0 DAY)

COLUMNS

这个按行过滤的表格会列出表格中的列。主账号 数据库级 IAM 权限和主账号 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能看到列 符合以下任一要求:

  • SELECTINSERTUPDATE 中的任意一个 针对当前列,直接将精细的访问权限控制权限 数据库角色,以及需要 当前数据库角色是否为成员或 public
  • SELECTINSERTUPDATE 精细访问权限控制 对包含当前列的表授予的权限 数据库角色、当前数据库角色属于该角色的角色,或 public
列名 类型 说明
TABLE_CATALOG STRING 未使用。始终为空字符串。
TABLE_SCHEMA STRING 未使用。始终为空字符串。
TABLE_NAME STRING 表的名称。
COLUMN_NAME STRING 列的名称。
ORDINAL_POSITION INT64 表中列的序号位置,从 1 开始。
COLUMN_DEFAULT STRING

默认值的 SQL 表达式的字符串表示 。如果列没有默认值,则为 NULL

注意:2022 年 3 月之前,COLUMN_DEFAULT 使用的类型 BYTES

DATA_TYPE STRING 包含在内,用于满足 SQL 标准。始终为 NULL。请参阅 第 SPANNER_TYPE
IS_NULLABLE STRING 指明列是否可以为 Null 的字符串。根据 则字符串为 YESNO,而不是布尔值。
SPANNER_TYPE STRING 列的数据类型
IS_GENERATED STRING 指明是否生成列的字符串。对于生成的列,字符串为 ALWAYS;对于非生成的列,该字符串为 NEVER
GENERATION_EXPRESSION STRING 表示所生成列的 SQL 表达式的字符串。如果该列不是生成的列,则为 NULL
IS_STORED STRING 指明是否存储生成的列的字符串。对于生成的列,字符串始终为 YES;对于非生成的列,该字符串始终为 NULL
SPANNER_STATE STRING 列的当前状态。向现有表添加的新的生成的已存储列可能需要经过多个用户可观察状态才能充分利用。可能的
    值如下:
  • WRITE_ONLY:正在回填列。“未读取” 允许。
  • COMMITTED:该列完全可用。

COLUMN_PRIVILEGES

这个按行过滤的表列出了在列级别授予 任何数据库角色,包括 public。主账号 数据库级 IAM 以及已被授予 spanner_info_reader 个系统角色或拥有该角色的成员可以查看以下位置中的所有行: 此视图。所有其他主账号只能看到符合以下条件的列的权限: 以下任一要求:

  • SELECTINSERTUPDATE 中的任意一个 针对当前列,直接将精细的访问权限控制权限 数据库角色,以及需要 当前数据库角色是否为成员或 public
  • SELECTINSERTUPDATE 精细访问权限控制 对包含当前列的表授予的权限 数据库角色、当前数据库角色属于该角色的角色,或 public
列名 类型 说明
TABLE_CATALOG STRING 未使用。始终为空字符串。
TABLE_SCHEMA STRING 未使用。始终为空字符串。
TABLE_NAME STRING 包含特权列的表的名称。
COLUMN_NAME STRING 特权列的名称。
PRIVILEGE_TYPE STRING SELECTINSERTUPDATE
GRANTEE STRING 授予此权限的数据库角色的名称。

TABLE_PRIVILEGES

这个按行过滤的表列出了在表级授予的所有权限, 数据库角色,包括 public。 使用数据库级 IAM 的主账号 以及已被授予 spanner_info_reader 个系统角色或拥有该角色的成员可以查看以下位置中的所有行: 此视图。所有其他主账号只能看到存在以下情况的表的权限: 的 SELECTINSERTUPDATEDELETE 精细访问权限控制 当前数据库角色以及需要 当前数据库角色是否为成员或 public

列名 类型 说明
TABLE_CATALOG STRING 未使用。始终为空字符串。
TABLE_SCHEMA STRING 未使用。始终为空字符串。
TABLE_NAME STRING 向其授予精细访问权限控制权限的表的名称。
PRIVILEGE_TYPE STRING SELECTINSERTUPDATE、 和DELETE
GRANTEE STRING 授予此权限的数据库角色的名称。

TABLE_CONSTRAINTS

此表为数据库中的表定义的每个限制条件都包含了一行。

列名 类型 说明
CONSTRAINT_CATALOG STRING 始终为空字符串。
CONSTRAINT_SCHEMA STRING 限制条件的架构名称。如果未命名,则为空字符串。
CONSTRAINT_NAME STRING 限制条件的名称。
TABLE_CATALOG STRING 受限表的目录名称。始终为空字符串。
TABLE_SCHEMA STRING 受限表的架构名称。如果未命名,则为空字符串。
TABLE_NAME STRING 受限表的名称。
CONSTRAINT_TYPE STRING 限制条件的类型。可能的
    值如下:
  • PRIMARY KEY
  • FOREIGN KEY
  • PLACEMENT KEY
  • CHECK
  • UNIQUE
IS_DEFERRABLE STRING 始终为 NO
INITIALLY_DEFERRED STRING 始终为 NO
ENFORCED STRING 始终为 YES

CONSTRAINT_TABLE_USAGE

此表列出了定义限制条件或限制条件使用的表。包括用于定义 PRIMARY KEYUNIQUE 限制条件的表。此外,还包括引用的 FOREIGN KEY 定义的表。

列名 类型 说明
TABLE_CATALOG STRING 受限表的目录名称。始终为空字符串。
TABLE_SCHEMA STRING 受限表的架构名称。如果未命名,则为空字符串。
TABLE_NAME STRING 受限表的名称。
CONSTRAINT_CATALOG STRING 限制条件的目录名称。始终为空字符串。
CONSTRAINT_SCHEMA STRING 限制条件的架构名称。如果未命名,则为空字符串。
CONSTRAINT_NAME STRING 限制条件的名称。

REFERENTIAL_CONSTRAINTS

此表包含一行有关每个 FOREIGN KEY 限制条件的信息。

列名 类型 说明
CONSTRAINT_CATALOG STRING 外键的目录名称。始终为空字符串。
CONSTRAINT_SCHEMA STRING 外键的架构名称。如果未命名,则为空字符串。
CONSTRAINT_NAME STRING 外键的名称。
UNIQUE_CONSTRAINT_CATALOG STRING 主键的目录名称,或外键的唯一限制条件 参考。始终为空字符串。
UNIQUE_CONSTRAINT_SCHEMA STRING 主键的架构名称或外部键的唯一限制条件 参考。如果未命名,则为空字符串。
UNIQUE_CONSTRAINT_NAME STRING 主键的名称或外键的唯一限制条件 参考。
MATCH_OPTION STRING 始终为 SIMPLE
UPDATE_RULE STRING 始终为 NO ACTION
DELETE_RULE STRING CASCADENO ACTION
SPANNER_STATE STRING 外键的当前状态。Spanner 未开始强制执行 该约束条件,直到创建外键的后备索引 已回填。索引准备就绪后,Spanner 会开始强制执行 验证现有数据的同时,为新事务添加约束条件。 可能的值和它们所代表的状态如下:
  • BACKFILLING_INDEXES:正在回填的索引。
  • VALIDATING_DATA:正在执行现有数据和新的写入操作 已通过验证。
  • WAITING_FOR_COMMIT:外键批量操作具有 也无需任何操作,但外键是 仍在等待处理。
  • COMMITTED:已提交架构更改。

CHECK_CONSTRAINTS

information_schema.CHECK_CONSTRAINTS 表包含关于 CHECKNOT NULL 关键字定义的各个 CHECK 限制条件的一行。

列名 类型 说明
CONSTRAINT_CATALOG STRING 限制条件的目录名称。此列从来不会为 null,但始终为空字符串。
CONSTRAINT_SCHEMA STRING 限制条件的架构名称。如果未命名,则为空字符串。
CONSTRAINT_NAME STRING 限制条件的名称。此列从来不会为 null。如果未在架构定义中明确指定,将分配系统定义的名称。
CHECK_CLAUSE STRING CHECK 限制条件的表达式。此列从来不会为 null。
SPANNER_STATE STRING CHECK 限制条件的当前状态。此列从来不会为 null。 可能的状态如下:
  • VALIDATING:Spanner 正在验证 现有数据
  • COMMITTED:此限制条件没有有效的架构更改。

KEY_COLUMN_USAGE

这个按行过滤的表格包含一行与各列的表格相关 受 PRIMARY KEYFOREIGN KEYUNIQUE 约束条件约束为键的 TABLE_CONSTRAINTS。使用数据库级 IAM 的主账号 以及已被授予 spanner_info_reader 个系统角色或拥有该角色的成员可以查看以下位置中的所有行: 此视图。所有其他主账号只能看到符合以下条件的列 条件:

  • SELECTINSERTUPDATE 中的任意一个 针对当前列,直接将精细的访问权限控制权限 数据库角色,以及需要 当前数据库角色是否为成员或 public
  • SELECTINSERTUPDATE 精细访问权限控制 对包含当前列的表授予的权限 数据库角色、当前数据库角色属于该角色的角色,或 public
列名 类型 说明
CONSTRAINT_CATALOG STRING 限制条件的目录名称。始终为空字符串。
CONSTRAINT_SCHEMA STRING 限制条件的架构名称。此列从来不会为 null。空 字符串(如果未命名)。
CONSTRAINT_NAME STRING 限制条件的名称。
TABLE_CATALOG STRING 受限列的目录名称。始终为空字符串。
TABLE_SCHEMA STRING 受限列的架构名称。此列从来不会为 null。 如果未命名,则为空字符串。
TABLE_NAME STRING 受限列的表的名称。
COLUMN_NAME STRING 列的名称。
ORDINAL_POSITION INT64 列在限制条件的键中的序号位置, 从值 1 开始。
POSITION_IN_UNIQUE_CONSTRAINT INT64 对于 FOREIGN KEY,此参数中列的序数位置 唯一约束条件,从值 1 开始。这个 对于其他限制条件类型,列为 null。

CONSTRAINT_COLUMN_USAGE

此表包含一行有关限制条件使用的每一列的信息。包含 PRIMARY KEYUNIQUE 列,以及 FOREIGN KEY 中引用的列 限制条件。

列名 类型 说明
TABLE_CATALOG STRING 列表的目录名称。始终为空字符串。
TABLE_SCHEMA STRING 列表的架构名称。此列从来不会为 null。一个 空字符串(如果未命名)。
TABLE_NAME STRING 列的表名称。
COLUMN_NAME STRING 限制条件使用的列的名称。
CONSTRAINT_CATALOG STRING 限制条件的目录名称。始终为空字符串。
CONSTRAINT_SCHEMA STRING 限制条件的架构名称。如果未命名,则为空字符串。
CONSTRAINT_NAME STRING 限制条件的名称。

TABLE_SYNONYMS

此表列出了表的同义词信息。

列名 类型 说明
TABLE_CATALOG STRING 未使用。始终为空字符串。
TABLE_SCHEMA STRING 未使用。始终为空字符串。
TABLE_NAME STRING 表的名称。
SYNONYM_CATALOG STRING 同义词的目录名称。
SYNONYM_SCHEMA STRING 同义词的架构名称。
SYNONYM_TABLE_NAME STRING 同义词的表的名称。

INDEXES

这个按行过滤的表列出了数据库中的索引。主账号 数据库级 IAM 权限和主账号 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能看到索引 符合以下任一要求:

  • SELECTINSERTUPDATE 中的任意一个 精细的访问权限控制权限是在列级别授予所有 当前数据库角色索引列、 当前数据库角色是否为成员或 public
  • SELECTINSERTUPDATE、 或DELETE精细的访问权限控制 对具有当前索引的表授予的特权 数据库角色、当前数据库角色属于该角色的角色,或 public
列名 类型 说明
TABLE_CATALOG STRING 目录的名称。始终为空字符串。
TABLE_SCHEMA STRING 架构的名称。如果未命名,则为空字符串。
TABLE_NAME STRING 表的名称。
INDEX_NAME STRING 索引的名称。包含 PRIMARY KEY 的表 具有一个伪索引条目,该条目使用名称为 PRIMARY_KEY,以允许 要确定的主键的值
INDEX_TYPE STRING 索引的类型。类型为 INDEXPRIMARY_KEY
PARENT_TABLE_NAME STRING 如前所述,二级索引可以在父表中交错 请参阅创建 二级索引。此列包含该父表的名称,或者 如果索引未交错,则为空字符串。
IS_UNIQUE BOOL 索引键是否必须是唯一的。
IS_NULL_FILTERED BOOL 索引是否包含值为 NULL 的条目。
INDEX_STATE STRING 索引的当前状态。可能的值及其状态 分别是:
  • PREPARE:为新索引创建空表。
  • WRITE_ONLY:回填新索引的数据。
  • WRITE_ONLY_CLEANUP:清理新索引。
  • WRITE_ONLY_VALIDATE_UNIQUE:检查中数据的唯一性 新索引。
  • READ_WRITE:正常索引操作。
SPANNER_IS_MANAGED BOOL 如果索引由 Spanner 管理,则为 TRUE;否则 FALSE。外键的二级后备索引由 Spanner。

INDEX_COLUMNS

这个按行过滤的表会列出索引中的列。主账号 数据库级 IAM 权限和主账号 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能看到索引 符合以下任一要求:

  • SELECTINSERTUPDATE 中的任意一个 精细的访问权限控制权限是在列级别授予所有 当前数据库角色索引列、 当前数据库角色是否为成员或 public
  • SELECTINSERTUPDATE 精细访问权限控制 对具有当前索引的表授予的权限 数据库角色、当前数据库角色属于该角色的角色,或 public
列名 类型 说明
TABLE_CATALOG STRING 目录的名称。始终为空字符串。
TABLE_SCHEMA STRING 架构的名称。如果未命名,则为空字符串。
TABLE_NAME STRING 表的名称。
INDEX_NAME STRING 索引的名称。
COLUMN_NAME STRING 列的名称。
ORDINAL_POSITION INT64 索引(或主索引)中列的序数位置 键),从 1 开始。此值为 NULL,适用于 非键列(例如,在 STORING 子句 索引)。
COLUMN_ORDERING STRING 列的排序。值为 ASCDESC 表示键列,NULL 表示非键列 列(例如,在 STORING 中指定的列) 索引的子句)。
IS_NULLABLE STRING 指明列是否可以为 Null 的字符串。在 符合 SQL 标准,字符串为 YESNO, 而不是布尔值。
SPANNER_TYPE STRING 列的数据类型

COLUMN_OPTIONS

这个按行过滤的表格会列出表格中的列选项。主账号 拥有数据库级 IAM 权限, 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能看到选项 对于符合以下任一要求的列:

  • SELECTINSERTUPDATE 中的任意一个 针对当前列,直接将精细的访问权限控制权限 数据库角色,以及需要 当前数据库角色是否为成员或 public
  • SELECTINSERTUPDATE 精细访问权限控制 对包含当前列的表授予的权限 数据库角色、当前数据库角色属于该角色的角色,或 public
列名 类型 说明
TABLE_CATALOG STRING 目录的名称。始终为空字符串。
TABLE_SCHEMA STRING 架构的名称。默认架构的名称为空,其他架构(例如,INFORMATION_SCHEMA 本身)的名称为非空。 此列从来不会为 null。
TABLE_NAME STRING 表的名称。
COLUMN_NAME STRING 列的名称。
OPTION_NAME STRING 唯一标识选项的 SQL 标识符。此标识符是 DDL 中 OPTIONS 子句的键。
OPTION_TYPE STRING 表示此选项值的类型的数据类型名称。
OPTION_VALUE STRING 描述此选项值的 SQL 字面量。此列的值必须作为查询的一部分进行分析。解析该值所得到的表达式必须可强制转换为 OPTION_TYPE。此列从来不会为 null。

SEQUENCES

下表列出了序列元数据。“SEQUENCES”是基于以下条件进行行过滤的: 授予细化的访问权限 查询。

列名 类型 说明
CATALOG STRING 包含序列的目录的名称。
SCHEMA STRING 包含序列的架构的名称。
NAME STRING 序列的名称。
DATA_TYPE STRING 序列值的类型。它使用 INT64 数据类型。

SEQUENCE_OPTIONS

下表包含序列的配置选项。SEQUENCE_OPTIONS 根据细粒度访问权限对行进行过滤(如果用户拥有 对它进行查询

列名 类型 说明
CATALOG STRING 包含序列的目录的名称。
SCHEMA STRING 包含序列的架构的名称。
NAME STRING 序列的名称。
OPTION_NAME STRING 序列选项的名称。
OPTION_TYPE STRING 表示此选项值的类型的数据类型名称。
OPTION_VALUE STRING 序列选项值。需要 解析该值的结果必须允许转换为 OPTION_TYPE

SPANNER_STATISTICS

下表列出了可用的查询优化器统计信息软件包。

列名 类型 说明
CATALOG_NAME STRING 目录的名称。始终为空字符串。
SCHEMA_NAME STRING 架构的名称。默认架构的名称为空,其他架构(例如,INFORMATION_SCHEMA 本身)的名称为非空。 此列从来不会为 null。
PACKAGE_NAME STRING 统计信息软件包的名称。
ALLOW_GC BOOL 如果统计信息软件包已免于垃圾回收,则为 FALSE collection;否则为 TRUE
必须将此属性设为 FALSE 才能 在提示中或通过客户端 API 引用统计信息包。

VIEWS

这个按行过滤的表列出了数据库中的视图。主账号 数据库级 IAM 权限和主账号 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能查看 SELECT精细访问权限控制 已向当前数据库角色授予当前数据库角色 数据库角色是否为成员或 public

列名 类型 说明
TABLE_CATALOG STRING 目录的名称。始终为空字符串。
TABLE_SCHEMA STRING 架构的名称。如果未命名,则为空字符串。
TABLE_NAME STRING 视图的名称。
VIEW_DEFINITION STRING 定义视图的查询的 SQL 文本。
SECURITY_TYPE STRING 视图的安全类型。可以是 INVOKERDEFINER

如需了解详情,请参阅视图简介

ROLES

这个按行过滤的表列出了已定义的数据库角色,可进行精细访问 控制,包括系统角色。主账号 数据库级 IAM 权限和主账号 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 可以查看所有数据库角色。所有其他主账号只能看到数据库 这些角色可以直接访问或通过 继承。

列名 类型 说明
ROLE_NAME STRING 数据库角色的名称。
IS_SYSTEM BOOL 如果数据库角色为 TRUE 系统角色; 否则为 FALSE

ROLE_GRANTEES

这个按行过滤的表列出了明确授予 数据库角色具有数据库级 IAM 权限的主账号 以及已被授予 spanner_info_reader 个系统角色或拥有该角色的成员可以查看以下位置中的所有行: 此视图。所有其他主账号只能查看授予 当前数据库角色或当前数据库角色所属的角色 成员。

因为所有数据库角色都是公共 角色,因此结果会忽略 是公共角色的隐式成员。

列名 类型 说明
ROLE_NAME STRING 被授予此成员资格的数据库角色的名称。
GRANTEE STRING 授予此成员资格的数据库角色的名称。

CHANGE_STREAMS

这个按行过滤的表列出了数据库的所有变更数据流以及 跟踪整个数据库,而不是跟踪特定表或列。主账号 拥有数据库级 IAM 权限, 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能看到更改 已针对当前已授予 SELECT 精细访问权限控制权限的数据流 数据库角色、当前数据库角色属于该角色的角色,或 public

列名 类型 说明
CHANGE_STREAM_CATALOG STRING 变更数据流的目录名称。始终为空字符串。
CHANGE_STREAM_SCHEMA STRING 此变更数据流的架构名称。始终为空字符串。
CHANGE_STREAM_NAME STRING 变更数据流的名称。
ALL BOOL 如果变更数据流跟踪整个数据库,则为 TRUEFALSE(如果此变更数据流跟踪特定表或 列。

CHANGE_STREAM_TABLES

这个按行过滤的表包含表和变更数据流的相关信息 的观众。每行描述一个表和一个变更数据流。主账号 拥有数据库级 IAM 权限, 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能看到以下行 已授予当前 SELECT 权限的变更数据流 数据库角色、当前数据库角色属于该角色的角色,或 public

CHANGE_STREAM_TABLES 中的数据不包含隐式关系 更改流来跟踪整个数据库。

列名 类型 说明
CHANGE_STREAM_CATALOG STRING 变更数据流的目录名称。始终为空字符串。
CHANGE_STREAM_SCHEMA STRING 变更数据流的架构名称。始终为空字符串。
CHANGE_STREAM_NAME STRING 此行所引用的变更数据流的名称。
TABLE_CATALOG STRING 表的目录名称。始终为空字符串。
TABLE_SCHEMA STRING 表架构的名称。始终为空字符串。
TABLE_NAME STRING 此行所引用的表的名称。
ALL_COLUMNS BOOL TRUE 如果此行的变更数据流跟踪整个 此行所引用的表格否则,FALSE

CHANGE_STREAM_COLUMNS

这个按行过滤的表格包含表格中列的相关信息以及变更 观看这些视频的直播每行描述一个变更数据流和一列。如果 变更数据流会跟踪整个表格,则该表格中的列不会 显示的信息。

拥有数据库级 IAM 权限的主账号,以及具备 已被授予 spanner_info_reader 系统角色或成员的访问权限 可以查看此视图中的所有行。所有其他主账号只能看到 向其授予 SELECT 权限的变更数据流所对应的行 当前数据库角色,以及当前数据库角色所属的角色; 或public

列名 类型 说明
CHANGE_STREAM_CATALOG STRING 变更数据流的目录名称。始终为空字符串。
CHANGE_STREAM_SCHEMA STRING 变更数据流的架构名称。始终为空字符串。
CHANGE_STREAM_NAME STRING 变更数据流的名称。
TABLE_CATALOG STRING 表的目录名称。始终为空字符串。
TABLE_SCHEMA STRING 表架构的名称。始终为空字符串。
TABLE_NAME STRING 此行所引用的表的名称。
COLUMN_NAME STRING 此行所引用的列的名称。

CHANGE_STREAM_OPTIONS

这个按行过滤的表包含变更数据流的配置选项。 拥有数据库级 IAM 权限的主账号,以及具备 已被授予 spanner_info_reader 系统角色或成员的访问权限 可以查看此视图中的所有行。所有其他主账号只能看到 针对已授予 SELECT 权限的变更数据流的选项 当前数据库角色,以及当前数据库角色所属的角色; 或public

列名 类型 说明
CHANGE_STREAM_CATALOG STRING 变更数据流的目录名称。始终为空字符串。
CHANGE_STREAM_SCHEMA STRING 变更数据流的架构名称。始终为空字符串。
CHANGE_STREAM_NAME STRING 变更数据流的名称。
OPTION_NAME STRING 变更数据流选项的名称。
OPTION_TYPE STRING 变更数据流选项的数据类型。
OPTION_VALUE STRING 变更数据流选项值。

CHANGE_STREAM_PRIVILEGES

这个按行过滤的表列出了针对所有更改授予的所有精细访问权限控制权限 流式传输到任何数据库角色,包括 public。主账号 数据库级 IAM 权限和主账号 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能看到权限 当前数据库角色授予当前数据库角色,授予 当前数据库角色是否为成员或 public

列名 类型 说明
CHANGE_STREAM_CATALOG STRING 包含变更数据流的目录的名称 (空字符串)。
CHANGE_STREAM_SCHEMA STRING 包含变更数据流的架构的名称 (空字符串)。
CHANGE_STREAM_NAME STRING 变更数据流的名称。
PRIVILEGE_TYPE STRING SELECT(变更数据流允许的唯一权限)。
GRANTEE STRING 授予此权限的数据库角色的名称。

ROUTINES

这个按行过滤的表列出了数据库的所有变更数据流读取函数。 拥有数据库级 IAM 权限的主账号,以及具备 已被授予 spanner_info_reader 系统角色或成员的访问权限 可以查看此视图中的所有行。所有其他主账号只能看到 具有 EXECUTE 精细访问权限控制权限的变更数据流读取函数 授予当前数据库角色,授予当前数据库 角色是否为成员,或者设置为 public

列名 类型 说明
SPECIFIC_CATALOG STRING 例程的目录名称。始终为空字符串。
SPECIFIC_SCHEMA STRING 例程架构的名称。始终为空字符串。
SPECIFIC_NAME STRING 例程的名称。可唯一标识日常安排,即使 其名称过载
ROUTINE_CATALOG STRING 例程的目录名称。始终为空字符串。
ROUTINE_SCHEMA STRING 例程架构的名称。始终为空字符串。
ROUTINE_NAME STRING 例程的名称。(如果是 overloading.)
ROUTINE_TYPE STRING 例程的类型(FUNCTIONPROCEDURE)。始终为 FUNCTION
DATA_TYPE STRING 例程返回的数据类型
ROUTINE_BODY STRING 例程正文的类型(SQLEXTERNAL)。
ROUTINE_DEFINITION STRING ROUTINE_BODY 的定义。
SECURITY_TYPE STRING 例程的安全类型。始终为 INVOKER

ROUTINE_OPTIONS

在此按行过滤的表格中,每项定义的更改所对应的每个选项都有一行 流读取函数。

拥有数据库级 IAM 权限的主账号,以及具备 已被授予 spanner_info_reader 系统角色或成员的访问权限 可以查看此视图中的所有行。所有其他主账号只能看到 用于变更数据流读取函数的选项,EXECUTE 可针对这些函数的精细访问权限控制 已向当前数据库角色授予当前数据库角色 数据库角色是否为成员或 public

列名 类型 说明
SPECIFIC_CATALOG STRING 例程的目录名称。始终为空字符串。
SPECIFIC_SCHEMA STRING 例程架构的名称。始终为空字符串。
SPECIFIC_NAME STRING 例程的名称。唯一标识例程,以防出现以下情况 非常复杂
OPTION_NAME STRING 唯一标识选项的 SQL 标识符。
OPTION_TYPE STRING OPTION_VALUE 的数据类型。
OPTION_VALUE STRING 描述此选项值的 SQL 字面量。 此列的值必须可作为查询的一部分进行解析。

PARAMETERS

这个按行过滤的表定义了每次读取变更数据流的参数 函数。每行描述一个变更数据流读取函数的一个参数。

拥有数据库级 IAM 权限的主账号,以及具备 已被授予 spanner_info_reader 系统角色或成员的访问权限 可以查看此视图中的所有行。所有其他主账号只能看到 变更数据流读取函数的参数,EXECUTE 可针对这些函数进行精细访问权限控制 已向当前数据库角色授予当前数据库角色 数据库角色是否为成员或 public

列名 类型 说明
SPECIFIC_CATALOG STRING 例程的目录名称。始终为空字符串。
SPECIFIC_SCHEMA STRING 例程架构的名称。始终为空字符串。
SPECIFIC_NAME STRING 例程的名称。唯一标识例程,以防出现以下情况 非常复杂
ORDINAL_POSITION INT64 例程中参数的序数位置,从 并将值设置为 1。
PARAMETER_NAME STRING 参数的名称。
DATA_TYPE STRING 参数的数据类型。

ROUTINE_PRIVILEGES

这个按行过滤的表列出了针对所有更改授予的所有精细访问权限控制权限 将读取函数流式传输到任何数据库角色,包括 public。 拥有数据库级 IAM 权限的主账号,以及具备 已被授予 spanner_info_reader 个系统角色或拥有该角色的成员可以查看以下位置中的所有行: 此视图。所有其他主账号只能查看对变更数据流授予的权限 将函数读取到当前数据库角色,以及当前 或 public 的数据库角色。

列名 类型 说明
SPECIFIC_CATALOG STRING 例程的目录名称。始终为空字符串。
SPECIFIC_SCHEMA STRING 例程架构的名称。始终为空字符串。
SPECIFIC_NAME STRING 例程的名称。唯一标识例程,以防出现以下情况 非常复杂
PRIVILEGE_TYPE STRING 始终为 EXECUTE
GRANTEE STRING 授予此权限的数据库角色的名称。

ROLE_TABLE_GRANTS

这个按行过滤的表列出了针对所有表授予的所有精细访问权限控制权限 任何数据库角色(包括 public)的访问权限和视图。主账号 数据库级 IAM 权限和主账号 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能看到权限 当前数据库角色及其角色 当前数据库角色是成员,不包括 public

列名称 类型 说明
GRANTOR STRING 未使用。始终为 NULL
GRANTEE STRING 授予此权限的数据库角色的名称。
TABLE_CATALOG STRING 未使用。始终为空字符串。
TABLE_SCHEMA STRING 未使用。始终为空字符串。
TABLE_NAME STRING 表或视图的名称。
PRIVILEGE_TYPE STRING 权限的类型(SELECTINSERTUPDATEDELETE)。
IS_GRANTABLE STRING 未使用。始终为 NO

ROLE_COLUMN_GRANTS

这个按行过滤的表列出了针对所有列授予的所有精细访问权限控制权限 任何数据库角色,包括 public。主账号 数据库级 IAM 权限和主账号 被授予了 spanner_info_reader 个系统角色或拥有该角色的成员可以查看以下位置中的所有行: 此视图。所有其他主账号只能看到以下列被授予的权限: 当前数据库角色,以及当前数据库角色所属的角色 成员,不包括 public

该视图包含 SELECTINSERTUPDATE 权限, 列继承自包含该列的表或视图。

列名称 类型 说明
GRANTOR STRING 未使用。始终为 NULL
GRANTEE STRING 拥有此权限的数据库角色的名称 已授予。
TABLE_CATALOG STRING 未使用。始终为空字符串。
TABLE_SCHEMA STRING 未使用。始终为空字符串。
TABLE_NAME STRING 包含该列的表或视图的名称。
COLUMN_NAME STRING 被授予权限的列的名称。
PRIVILEGE_TYPE STRING 权限的类型(SELECTINSERTUPDATE)。
IS_GRANTABLE STRING 未使用。始终为 NO

ROLE_CHANGE_STREAM_GRANTS

这个按行过滤的表格列出了针对所有更改授予的 SELECT 权限 流式传输到任何数据库角色,包括 public。主账号 数据库级 IAM 权限和主账号 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能看到权限 当前数据库角色以及 当前数据库角色是成员,不包括 public

列名称 类型 说明
CHANGE_STREAM_CATALOG STRING 未使用。始终为空字符串。
CHANGE_STREAM_SCHEMA STRING 包含变更数据流的架构的名称。
CHANGE_STREAM_NAME STRING 变更数据流的名称。
PRIVILEGE_TYPE STRING 权限的类型(仅限 SELECT)。
GRANTEE STRING 授予此权限的数据库角色的名称。

ROLE_MODEL_GRANTS

这个按行过滤的表列出了针对所有模型授予的所有精细访问权限控制权限 任何数据库角色,包括 public。主账号 数据库级 IAM 权限和主账号 授予了 spanner_info_reader 系统角色或该系统角色的成员访问权限 角色可以查看此视图中的所有行。所有其他主账号只能看到权限 当前数据库角色及其角色 当前数据库角色是成员,不包括 public

列名称 类型 说明
GRANTOR STRING 未使用。始终为 NULL
GRANTEE STRING 授予此权限的数据库角色的名称。
MODEL_CATALOG STRING 未使用。始终为空字符串。
MODEL_SCHEMA STRING 未使用。始终为空字符串。
MODEL_NAME STRING 模型的名称。
PRIVILEGE_TYPE STRING 权限的类型 (EXECUTE)。
IS_GRANTABLE STRING 未使用。始终为 NO

ROLE_ROUTINE_GRANTS

这个按行过滤的表格列出了针对所有更改授予的 EXECUTE 权限 将读取函数流式传输到任何数据库角色,包括 public。主账号 IAM 数据库级权限以及已被授予 spanner_info_reader 个系统角色或拥有该角色的成员可以查看以下位置中的所有行: 此视图。所有其他主账号只能查看对变更数据流授予的权限 将函数读取到当前数据库角色以及当前 数据库角色是成员,不包括 public

列名 类型 说明
GRANTOR STRING 未使用。始终为 NULL
GRANTEE STRING 被授予权限的角色的名称。
SPECIFIC_CATALOG STRING 例程目录的名称。
SPECIFIC_SCHEMA STRING 例程架构的名称。
SPECIFIC_NAME STRING 例程的名称。唯一标识例程,以防出现以下情况 非常复杂
PRIVILEGE_TYPE STRING 授予的权限类型。始终为 EXECUTE
IS_GRANTABLE STRING 未使用。始终为 NO

MODELS

此表格列出了数据库的所有相关指标 models 实例。

列名 类型 说明
MODEL_CATALOG STRING 目录的名称。始终为空字符串。
MODEL_SCHEMA STRING 此模型架构的名称。始终为空字符串。
MODEL_NAME STRING 模型的名称。
IS_REMOTE BOOL 如果这是远程模型,则为 TRUEFALSE(如果是 是一种代管式模型。

MODEL_OPTIONS

下表包含模型的配置选项。

列名 类型 说明
MODEL_CATALOG STRING 目录的名称。始终为空字符串。
MODEL_SCHEMA STRING 此模型架构的名称。始终为空字符串。
MODEL_NAME STRING 模型的名称。
OPTION_NAME STRING 模型选项的名称。
OPTION_TYPE STRING 模型选项的数据类型。
OPTION_VALUE STRING 模型选项值。

MODEL_COLUMNS

下表列出了模型中的列。

列名 类型 说明
MODEL_CATALOG STRING 目录的名称。始终为空字符串。
MODEL_SCHEMA STRING 此模型架构的名称。始终为空字符串。
MODEL_NAME STRING 模型的名称。
COLUMN_KIND STRING 模型列种类。以下各项中的一项:"INPUT""OUTPUT"
COLUMN_NAME STRING 列的名称。
DATA_TYPE STRING 列的标准 SQL 数据类型。
ORDINAL_POSITION INT64 要保留的列的序数位置,从 1 开始 声明列的顺序。
IS_EXPLICIT BOOL 如果是在 DDL 中明确指定的列,则为 TRUE; 如果从端点中发现了此列,则返回 FALSE

MODEL_COLUMN_OPTIONS

此表包含模型列的配置选项。

列名 类型 说明
MODEL_CATALOG STRING 目录的名称。始终为空字符串。
MODEL_SCHEMA STRING 此模型架构的名称。始终为空字符串。
MODEL_NAME STRING 模型的名称。
COLUMN_KIND STRING 模型列种类。以下各项中的一项:"INPUT""OUTPUT"
COLUMN_NAME STRING 列的名称。
OPTION_NAME STRING 模型列选项的名称。
OPTION_TYPE STRING 模型列选项的数据类型。
OPTION_VALUE STRING 模型列选项值。

MODEL_PRIVILEGES

这个按行过滤的表列出了在模型级授予的所有权限, 数据库角色,包括 public。 使用数据库级 IAM 的主账号 以及已被授予 spanner_info_reader 个系统角色或拥有该角色的成员可以查看以下位置中的所有行: 此视图。所有其他主账号只能看到符合以下条件的模型的权限: EXECUTE 精细的访问权限控制 权限授予了当前数据库角色,也授予了 当前数据库角色是否为成员或 public

列名 类型 说明
MODEL_CATALOG STRING 未使用。始终为空字符串。
MODEL_SCHEMA STRING 未使用。始终为空字符串。
MODEL_NAME STRING 向其授予精细访问权限控制权限的模型的名称。
PRIVILEGE_TYPE STRING EXECUTE>
GRANTEE STRING 授予此权限的数据库角色的名称。

PROPERTY_GRAPHS

这个按行过滤的表格列出了 属性图表 数据。具有数据库级 IAM 权限的主账号 以及已被授予 spanner_info_reader 系统访问权限的主账号 或具有该角色的成员可以查看此视图中的所有行。所有其他 只有在满足查看全部要求的情况下,主账号才能查看属性图表 用来定义这些图表的表格

列名 类型 说明
PROPERTY_GRAPH_CATALOG STRING 目录的名称。始终为空字符串。
PROPERTY_GRAPH_SCHEMA STRING 架构的名称。如果未命名,则为空字符串。
PROPERTY_GRAPH_NAME STRING 属性图表的名称。
PROPERTY_GRAPH_METADATA_JSON JSON JSON 格式的属性图定义。

PROPERTY_GRAPH_METADATA_JSON 列包含一个 PropertyGraph JSON 对象 定义如下:

JSON 对象名称 字段名称 JSON 类型 说明
PropertyGraph catalog string 目录的名称。始终为空字符串。
schema string 架构的名称。如果未命名,则为空字符串。
name string 属性图表的名称。
nodeTables array<object> 节点的 GraphElementTable 对象的列表。
edgeTables array<object> 边的 GraphElementTable 对象列表。
labels array<object> GraphElementLabel 对象的列表。
propertyDeclarations array<object> GraphPropertyDeclaration 对象的列表。
GraphElementTable name string 图表元素表格的名称。
kind string NODEEDGE
baseCatalogName string 包含基表的目录的名称。
baseSchemaName string 包含基表的架构的名称。
baseTableName string 用于创建元素的输入表的名称。
keyColumns array<string> 构成元素键的列名称。
labelNames array<string> 附加到此元素表的标签名称。
propertyDefinitions array<object> GraphPropertyDefinition 对象的列表。
sourceNodeTable object 一个 GraphNodeTableReference 对象。仅当 kindEDGE
destinationNodeTable object 一个 GraphNodeTableReference 对象。仅当 kindEDGE
GraphNodeTableReference nodeTableName string 图表元素表格的名称。
edgeTableColumns array<string> 与来源关联的列的名称和 边缘的目标键。
nodeTableColumns array<string> 与来源关联的列的名称和 节点的目标键。
GraphElementLabel name string 标签的名称。
propertyDeclarationNames array<string> 与此标签相关联的属性名称。
GraphPropertyDeclaration name string 属性的名称。
type string 属性的类型。
GraphPropertyDefinition propertyDeclarationName string 属性的名称。
valueExpressionSql string 用于定义属性的表达式。

示例

返回有关用户架构中每个表的信息:

SELECT
  t.table_name,
  t.parent_table_name
FROM
  information_schema.tables AS t
WHERE
  t.table_catalog = ''
  AND
  t.table_schema = ''
ORDER BY
  t.table_catalog,
  t.table_schema,
  t.table_name

返回 INFORMATION_SCHEMA 中所有表的名称:

SELECT
  t.table_name
FROM
  information_schema.tables AS t
WHERE
  t.table_schema = "SPANNER_SYS"

返回有关用户表 MyTable 中的列的信息:

SELECT
  t.column_name,
  t.spanner_type,
  t.is_nullable
FROM
  information_schema.columns AS t
WHERE
  t.table_catalog = ''
  AND
  t.table_schema = ''
  AND
  t.table_name = 'MyTable'
ORDER BY
  t.table_catalog,
  t.table_schema,
  t.table_name,
  t.ordinal_position

返回有关数据库的默认主要区域的信息。如果未设置默认主要区域,则返回空值:

SELECT
  s.option_name,
  s.option_value
FROM
  information_schema.database_options s
WHERE
  s.option_name = 'default_leader'

返回有关用户架构中每个索引的信息:

SELECT
  t.table_name,
  t.index_name,
  t.parent_table_name
FROM
  information_schema.indexes AS t
WHERE
  t.table_catalog = ''
  AND
  t.table_schema = ''
  AND
  t.index_type != 'PRIMARY_KEY'
ORDER BY
  t.table_catalog,
  t.table_schema,
  t.table_name,
  t.index_name

返回使用默认值以外的选项的所有列:

SELECT
  t.table_name,
  t.column_name,
  t.option_type,
  t.option_value,
  t.option_name
FROM
  information_schema.column_options AS t
WHERE
  t.table_catalog = ''
AND
  t.table_schema = ''

返回当前与优化工具相关的数据库选项:

SELECT
  s.option_name,
  s.option_value
FROM
  information_schema.database_options s
WHERE
  s.schema_name=''
  AND s.option_name IN ('optimizer_version',
    'optimizer_statistics_package')

返回所有可用的统计信息包:

SELECT
  *
FROM
  information_schema.spanner_statistics;

返回所有序列:

SELECT
  *
FROM
  information_schema.sequences;

返回名为“MySequence”的序列的所有序列选项

SELECT
  *
FROM
  information_schema.sequence_options WHERE name="MySequence";

返回所有属性图的名称及其定义:

SELECT
  property_graph_name,
  property_graph_metadata_json
FROM
  information_schema.property_graphs

返回所有属性图的名称及其标签和属性:

SELECT
  property_graph_name,
  property_graph_metadata_json.labels,
  property_graph_metadata_json.propertyDeclarations
FROM
  information_schema.property_graphs

后续步骤

  • 了解可用的内省工具以 可帮助您调查数据库问题。