目录搜索
文字
分享

34.33. routines

视图routines包含当前数据库中的所有函数。 只有当前用户有访问权限(可能是所有者或者有特定权限)的函数才显示出来。

Table 34-31. routines 字段

名称 数据类型 描述
specific_catalog sql_identifier 包含该函数的数据库名称(总是当前数据库)
specific_schema sql_identifier 包含该函数的模式名称
specific_name sql_identifier 函数的"specific name" "具体名字"。这是一个在模式里唯一标识该函数的名字, 即使函数的真是名字是重载的也如此。 具体名字的格式没有定义,我们应该只是用它和其它具体过程名的实例进行比较。
routine_catalog sql_identifier 包含该函数的数据库名称(总是当前数据库)
routine_schema sql_identifier 包含该函数的模式名称
routine_name sql_identifier 函数的名称(在重载的时候可能重复)
routine_type character_data 总是FUNCTION(未来可能会有其它类型的过程。)
module_catalog sql_identifier 应用于一个PostgreSQL里没有的特性
module_schema sql_identifier 应用于一个PostgreSQL里没有的特性
module_name sql_identifier 应用于一个PostgreSQL里没有的特性
udt_catalog sql_identifier 应用于一个PostgreSQL里没有的特性
udt_schema sql_identifier 应用于一个PostgreSQL里没有的特性
udt_name sql_identifier 应用于一个PostgreSQL里没有的特性
data_type character_data 如果这是一个内置类型,则为函数的返回数据类型, 如果是某种数组, 则为ARRAY(这个时候,参阅element_types), 否则就是 USER-DEFINED (这种情况下,类型在type_udt_name和相关字段中标识)。
character_maximum_length cardinal_number 总是为空,因为这个信息并不应用于PostgreSQL里的返回数据类型
character_octet_length cardinal_number 总是为空,因为这个信息并不应用于PostgreSQL里的返回数据类型
character_set_catalog sql_identifier 应用于一个PostgreSQL里没有的特性
character_set_schema sql_identifier 应用于一个PostgreSQL里没有的特性
character_set_name sql_identifier 应用于一个PostgreSQL里没有的特性
collation_catalog sql_identifier 应用于一个PostgreSQL里没有的特性
collation_schema sql_identifier 应用于一个PostgreSQL里没有的特性
collation_name sql_identifier 应用于一个PostgreSQL里没有的特性
numeric_precision cardinal_number 总是为空,因为这个信息并不应用于PostgreSQL里的返回数据类型
numeric_precision_radix cardinal_number 总是为空,因为这个信息并不应用于PostgreSQL里的返回数据类型
numeric_scale cardinal_number 总是为空,因为这个信息并不应用于PostgreSQL里的返回数据类型
datetime_precision cardinal_number 总是为空,因为这个信息并不应用于PostgreSQL里的返回数据类型
interval_type character_data 总是为空,因为这个信息并不应用于PostgreSQL里的返回数据类型
interval_precision character_data 总是为空,因为这个信息并不应用于PostgreSQL里的返回数据类型
type_udt_catalog sql_identifier 函数的返回数据类型定义所在的数据库名称(总是当前数据库)
type_udt_schema sql_identifier 函数的返回数据类型定义所在的模式名称
type_udt_name sql_identifier 该函数的返回数据类型
scope_catalog sql_identifier 应用于一个PostgreSQL里没有的特性
scope_schema sql_identifier 应用于一个PostgreSQL里没有的特性
scope_name sql_identifier 应用于一个PostgreSQL里没有的特性
maximum_cardinality cardinal_number 总是为空,因为这个信息并不应用于PostgreSQL里的返回数据类型
dtd_identifier sql_identifier 一个这个函数返回的数据类型的数据类型描述符的标识符,在所有属于这个函数的数据类型描述符中唯一。 这个描述符主要用于和其它这样的标识符进行连接。 (标识符具体的格式没有定义,并且不保证在将来的版本中保持相同。)
routine_body character_data 如果函数是 SQL 函数,那么 SQL,否则是EXTERNAL
routine_definition character_data 函数的源代码文本(如果当前用户不是函数所有者,则为空)。 (根据 SQL 标准,这个字段只又在routine_bodySQL的时候才使用, 但是在PostgreSQL里,这个字段将包含创建函数的时候所声明的任何源文本。)
external_name character_data 如果这个函数是一个 C 函数,那么是函数的外部名字(链接符号); 否则为空。(这个字段的数值和routine_definition里显示的数值相同。)
external_language character_data 书写这个函数使用的语言
parameter_style character_data 总是GENERAL(SQL标准定义了其它参数类型,那些类型不适用于PostgreSQL。)
is_deterministic yes_or_no 如果这个函数声明为不变的(immutable)(在 SQL 标准里叫确定的(deterministic)), 那么是 YES,否则是NO。 (在PostgreSQL 里你无法通过信息模式查询其它可用的易失性级别。)
sql_data_access character_data 总是MODIFIES,意思是这个函数可能修改 SQL 数据。 这个信息对PostgreSQL没啥作用。
is_null_call yes_or_no 如果函数任意输入参数为空,函数则自动返回空,则为YES,否则为NO
sql_path character_data 应用于一个PostgreSQL里没有的特性
schema_level_routine yes_or_no 总是YES(对应的方面是一个用户定义类型的方法,这是一个PostgreSQL里没有的特性。)
max_dynamic_result_sets cardinal_number 应用于一个PostgreSQL里没有的特性
is_user_defined_cast yes_or_no 应用于一个PostgreSQL里没有的特性
is_implicitly_invocable yes_or_no 应用于一个PostgreSQL里没有的特性
security_type character_data 如果这个函数以当前用户的权限运行,则为INVOKER, 如果函数以定义它的用户的权限运行,则为DEFINER
to_sql_specific_catalog sql_identifier 应用于一个PostgreSQL里没有的特性
to_sql_specific_schema sql_identifier 应用于一个PostgreSQL里没有的特性
to_sql_specific_name sql_identifier 应用于一个PostgreSQL里没有的特性
as_locator yes_or_no 应用于一个PostgreSQL里没有的特性
created time_stamp 应用于一个PostgreSQL里没有的特性
last_altered time_stamp 应用于一个PostgreSQL里没有的特性
new_savepoint_level yes_or_no 应用于一个PostgreSQL里没有的特性
is_udt_dependent yes_or_no 应用于一个PostgreSQL里没有的特性
result_cast_from_data_type character_data 应用于一个PostgreSQL里没有的特性
result_cast_as_locator yes_or_no 应用于一个PostgreSQL里没有的特性
result_cast_char_max_length cardinal_number 应用于一个PostgreSQL里没有的特性
result_cast_char_octet_length character_data 应用于一个PostgreSQL里没有的特性
result_cast_char_set_catalog sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_char_set_schema sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_char_set_name sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_collation_catalog sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_collation_schema sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_collation_name sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_numeric_precision cardinal_number 应用于一个PostgreSQL里没有的特性
result_cast_numeric_precision_radix cardinal_number 应用于一个PostgreSQL里没有的特性
result_cast_numeric_scale cardinal_number 应用于一个PostgreSQL里没有的特性
result_cast_datetime_precision character_data 应用于一个PostgreSQL里没有的特性
result_cast_interval_type character_data 应用于一个PostgreSQL里没有的特性
result_cast_interval_precision character_data 应用于一个PostgreSQL里没有的特性
result_cast_type_udt_catalog sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_type_udt_schema sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_type_udt_name sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_scope_catalog sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_scope_schema sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_scope_name sql_identifier 应用于一个PostgreSQL里没有的特性
result_cast_maximum_cardinality cardinal_number 应用于一个PostgreSQL里没有的特性
result_cast_dtd_identifier sql_identifier 应用于一个PostgreSQL里没有的特性