Documentation
/ SQL
/ Meta Queries
Information Schema
information_schema
中的视图是 SQL 标准视图,用于描述数据库的目录条目。这些视图可以过滤以获取有关特定列或表的信息。
DuckDB 的实现基于 PostgreSQL 的信息模式。
列 |
描述 |
类型 |
示例 |
character_set_catalog |
目前未实现 – 始终为 NULL 。 |
VARCHAR |
NULL |
character_set_schema |
目前未实现 – 始终为 NULL 。 |
VARCHAR |
NULL |
character_set_name |
字符集的名称,目前实现为显示数据库编码的名称。 |
VARCHAR |
'UTF8' |
character_repertoire |
字符集,如果编码是UTF8 ,则显示UCS ,否则只显示编码名称。 |
VARCHAR |
'UCS' |
form_of_use |
字符编码形式,与数据库编码相同。 |
VARCHAR |
'UTF8' |
default_collate_catalog |
包含默认排序规则的数据库名称(始终为当前数据库)。 |
VARCHAR |
'my_db' |
default_collate_schema |
包含默认排序规则的模式的名称。 |
VARCHAR |
'pg_catalog' |
default_collate_name |
默认排序规则的名称。 |
VARCHAR |
'ucs_basic' |
描述列目录信息的视图是 information_schema.columns
。它列出了数据库中存在的列,并具有以下布局:
列 |
描述 |
类型 |
示例 |
table_catalog |
包含表的数据库名称(始终为当前数据库)。 |
VARCHAR |
'my_db' |
table_schema |
包含表的模式名称。 |
VARCHAR |
'main' |
table_name |
表的名称。 |
VARCHAR |
'widgets' |
column_name |
列的名称。 |
VARCHAR |
'price' |
ordinal_position |
列在表中的顺序位置(从1开始计数)。 |
INTEGER |
5 |
column_default |
列的默认表达式。 |
VARCHAR |
1.99 |
is_nullable |
YES 如果列可能为空,NO 如果已知列不为空。 |
VARCHAR |
'YES' |
data_type |
列的数据类型。 |
VARCHAR |
'DECIMAL(18, 2)' |
character_maximum_length |
如果 data_type 标识的是字符或位字符串类型,则为声明的最大长度;对于所有其他数据类型或如果未声明最大长度,则为 NULL 。 |
INTEGER |
255 |
character_octet_length |
如果 data_type 标识一个字符类型,则为一个数据项的最大可能长度(以字节为单位);对于所有其他数据类型为 NULL 。最大字节长度取决于声明的字符最大长度(见上文)和字符编码。 |
INTEGER |
1073741824 |
numeric_precision |
如果 data_type 标识为数值类型,此列包含该列类型的(声明或隐式)精度。精度表示有效数字的位数。对于所有其他数据类型,此列为 NULL 。 |
INTEGER |
18 |
numeric_scale |
如果 data_type 标识为数值类型,此列包含此列类型的(声明或隐式)比例。精度表示有效数字的数量。对于所有其他数据类型,此列为 NULL 。 |
INTEGER |
2 |
datetime_precision |
如果 data_type 标识为日期、时间、时间戳或间隔类型,此列包含该列类型的(声明或隐式的)小数秒精度,即在秒值的小数点后保留的十进制位数。DuckDB 目前不支持小数秒。对于所有其他数据类型,此列为 NULL 。 |
INTEGER |
0 |
此视图描述了当前数据库中由某些约束使用的所有列。对于检查约束,此视图标识了检查表达式中使用的列。对于非空约束,此视图标识了定义约束的列。对于外键约束,此视图标识了外键引用的列。对于唯一或主键约束,此视图标识了受约束的列。
Column |
Description |
Type |
Example |
table_catalog |
包含被某些约束使用的列的表的数据库名称(始终是当前数据库) |
VARCHAR |
'my_db' |
table_schema |
包含被某些约束使用的列的表所在的模式名称 |
VARCHAR |
'main' |
table_name |
包含被某些约束使用的列的表名 |
VARCHAR |
'widgets' |
column_name |
被某些约束使用的列的名称 |
VARCHAR |
'price' |
constraint_catalog |
包含约束的数据库名称(始终为当前数据库) |
VARCHAR |
'my_db' |
constraint_schema |
包含约束的模式的名称 |
VARCHAR |
'main' |
constraint_name |
约束的名称 |
VARCHAR |
'exam_id_students_id_fkey' |
Column |
Description |
Type |
Example |
constraint_catalog |
包含约束的数据库名称(始终为当前数据库)。 |
VARCHAR |
'my_db' |
constraint_schema |
包含约束的模式的名称。 |
VARCHAR |
'main' |
constraint_name |
约束的名称。 |
VARCHAR |
'exams_exam_id_fkey' |
table_catalog |
包含受此约束限制的列的表的数据库名称(始终为当前数据库)。 |
VARCHAR |
'my_db' |
table_schema |
包含受此约束限制的列的表所在的模式名称。 |
VARCHAR |
'main' |
table_name |
包含受此约束限制的列的表名。 |
VARCHAR |
'exams' |
column_name |
受此约束限制的列的名称。 |
VARCHAR |
'exam_id' |
ordinal_position |
列在约束键中的顺序位置(从1开始计数)。 |
INTEGER |
1 |
position_in_unique_constraint |
对于外键约束,引用列在其唯一约束中的序号位置(从1 开始计数);否则为NULL 。 |
INTEGER |
1 |
Column |
Description |
Type |
Example |
constraint_catalog |
包含约束的数据库名称(始终为当前数据库)。 |
VARCHAR |
'my_db' |
constraint_schema |
包含约束的模式的名称。 |
VARCHAR |
main |
constraint_name |
约束的名称。 |
VARCHAR |
exam_id_students_id_fkey |
unique_constraint_catalog |
包含外键约束引用的唯一或主键约束的数据库名称。 |
VARCHAR |
'my_db' |
unique_constraint_schema |
包含外键约束引用的唯一或主键约束的模式的名称。 |
VARCHAR |
'main' |
unique_constraint_name |
外键约束引用的唯一或主键约束的名称。 |
VARCHAR |
'students_id_pkey' |
match_option |
外键约束的匹配选项。始终为 NONE 。 |
VARCHAR |
NONE |
update_rule |
外键约束的更新规则。始终为 NO ACTION 。 |
VARCHAR |
NO ACTION |
delete_rule |
外键约束的删除规则。始终为 NO ACTION 。 |
VARCHAR |
NO ACTION |
顶级目录视图是 information_schema.schemata
。它列出了数据库中的目录和模式,并具有以下布局:
Column |
Description |
Type |
Example |
catalog_name |
包含该模式的数据库的名称。 |
VARCHAR |
'my_db' |
schema_name |
模式的名称。 |
VARCHAR |
'main' |
schema_owner |
模式所有者的名称。尚未实现。 |
VARCHAR |
'duckdb' |
default_character_set_catalog |
适用于DuckDB中不可用的功能。 |
VARCHAR |
NULL |
default_character_set_schema |
适用于DuckDB中不可用的功能。 |
VARCHAR |
NULL |
default_character_set_name |
适用于DuckDB中不可用的功能。 |
VARCHAR |
NULL |
sql_path |
数据库的文件系统位置。目前未实现。 |
VARCHAR |
NULL |
描述表和视图的目录信息的视图是 information_schema.tables
。它列出了数据库中存在的表,并具有以下布局:
Column |
Description |
Type |
Example |
table_catalog |
表或视图所属的目录。 |
VARCHAR |
'my_db' |
table_schema |
表或视图所属的模式。 |
VARCHAR |
'main' |
table_name |
表或视图的名称。 |
VARCHAR |
'widgets' |
table_type |
表的类型。其中之一:BASE TABLE , LOCAL TEMPORARY , VIEW . |
VARCHAR |
'BASE TABLE' |
self_referencing_column_name |
适用于DuckDB中不可用的功能。 |
VARCHAR |
NULL |
reference_generation |
适用于DuckDB中不可用的功能。 |
VARCHAR |
NULL |
user_defined_type_catalog |
如果表是类型表,则包含基础数据类型的数据库名称(始终是当前数据库),否则为NULL 。目前未实现。 |
VARCHAR |
NULL |
user_defined_type_schema |
如果表是类型表,则包含基础数据类型的模式名称,否则为NULL 。目前未实现。 |
VARCHAR |
NULL |
user_defined_type_name |
如果表是类型表,则为基础数据类型的名称,否则为NULL 。目前未实现。 |
VARCHAR |
NULL |
is_insertable_into |
YES 如果表可以插入数据,NO 如果不能插入(基础表总是可以插入数据,视图不一定。) |
VARCHAR |
'YES' |
is_typed |
YES 如果表是类型表,NO 如果不是。 |
VARCHAR |
'NO' |
commit_action |
尚未实现。 |
VARCHAR |
'NO' |
Column |
Description |
Type |
Example |
constraint_catalog |
Name of the database that contains the constraint (always the current database). |
VARCHAR |
'my_db' |
constraint_schema |
Name of the schema that contains the constraint. |
VARCHAR |
'main' |
constraint_name |
Name of the constraint. |
VARCHAR |
'exams_exam_id_fkey' |
table_catalog |
包含表的数据库名称(始终为当前数据库)。 |
VARCHAR |
'my_db' |
table_schema |
包含表的模式名称。 |
VARCHAR |
'main' |
table_name |
表的名称。 |
VARCHAR |
'exams' |
constraint_type |
约束类型:CHECK , FOREIGN KEY , PRIMARY KEY , 或 UNIQUE . |
VARCHAR |
'FOREIGN KEY' |
is_deferrable |
YES 如果约束是可延迟的,NO 如果不是。 |
VARCHAR |
'NO' |
initially_deferred |
如果约束是可延迟的并且最初是延迟的,则为YES ,否则为NO 。 |
VARCHAR |
'NO' |
enforced |
总是 YES . |
VARCHAR |
'YES' |
nulls_distinct |
如果约束是唯一约束,则YES 表示该约束将NULL 视为不同的值,NO 表示将NULL 视为相同的值,否则对于其他类型的约束为NULL 。 |
VARCHAR |
'YES' |
还提供了几个函数来查看数据库中配置的目录和模式的详细信息。
函数 |
描述 |
示例 |
结果 |
current_catalog() |
返回当前活动目录的名称。默认为内存。 |
current_catalog() |
'memory' |
current_schema() |
返回当前活动模式的名称。默认为main。 |
current_schema() |
'main' |
current_schemas(boolean) |
返回模式列表。传递一个true 参数以包含隐式模式。 |
current_schemas(true) |
['temp', 'main', 'pg_catalog'] |