CREATE TYPE 声明用于指定类型的名称及其属性、方法和其他属性。

CREATE TYPE 声明创建或替换以下规范:

  • 抽象数据类型(ADT)

  • 独立的可变数组(VARRAY)类型

  • 独立嵌套表类型

  • 不完整对象类型

    不完整类型是由前向类型定义创建的类型。之所以称为不完整,是因为它具有名称,但没有属性或方法。它可以被其他类型引用,允许自定义相互引用的类型。 但是,必须先创建完成类型,然后才能用于创建表的列、对象列或嵌套表类型的列。

CREATE TYPE BODY 声明自带实现该类型的代码。

说明

  • 如果创建的类型规范仅声明属性而不声明方法,则无需创建 Body。

  • 使用 CREATE TYPE 声明,可以创建嵌套表和 VARRAY 类型,但不能创建关联数组。在 PL 块或包中,可以定义三种集合类型。

前提条件

要在 Schema 中创建类型,您必须具有 CREATE TYPE 的系统权限。要在其他用户的 Schema 中创建类型,您必须具有 CREATE ANY TYPE 的系统权限。您可以直接获得这些权限,也可以通过角色获取权限。

必须明确授予该类型的所有者 EXECUTE 对象权限,以访问该类型的定义中引用的所有其他类型,或者必须向该类型所有者授予 EXECUTE ANY TYPE 系统权限。所有者无法通过角色获得这些权限。

如果类型所有者打算授予其他用户对该类型的访问权限,则必须使用 GRANT OPTION 为所有者授予该类型的 EXECUTE 对象权限,或者通过 ADMIN OPTION 授予所有者 EXECUTE ANY TYPE 系统权限。否则,类型所有者没有足够的权限来授予其他用户该类型的访问权限。

语法

说明

本章节只包含部分重点语法节点的格式。

  • create_type_stmt 格式为:

    1create_type_stmt

  • plsql_type_spec_source 格式为:

    2plsql_type_spec_source

  • object_type_def 格式为:

    4object_type_def

  • attr_and_element_spec 格式为:

    13attr_and_element_spec

  • element_spec 格式为:

    element_spec

  • el_element_spec_list_cc 格式为:

    el_element_spec_list_cc

  • element_spec_long 格式为:

    element_spec_long

  • inheritance_final_instantiable_clause 格式为:

    inheritance_final_instantiable_clause

  • inheritance_overriding_instantiable_clause 格式为:

    inheritance_overriding_instantiable_clause

  • subprogram_spec 格式为:

    subprogram_spec

  • proc_or_func_spec 格式为:

    proc_or_func_spec

语义

语法

关键字或语法节点

说明

create_type_stmt

OR REPLACE

重新创建该类型(如果存在),然后重新编译。

在重新定义类型之前被授予权限的用户仍然可以访问该类型,而无需重新获得权限。如果任何基于函数的索引依赖于该类型,则数据库会将索引标记为 DISABLED。

plsql_type_spec_source

pl_schema_name

包含类型的 Schema 的名称。 默认值为您的 Schema。

TYPE

ADT 的名称、嵌套表类型或 VARRAY 类型。

varray_type_def

将类型创建为元素的有序集合,每个元素具有相同的数据类型。

nested_table_type_def

创建一个类型的嵌套表,命名为 datatype

object_type_def

object_type_def

创建一个 ADT。形成数据结构的变量称为属性(Attributes)。定义 ADT 行为的成员子程序称为方法(Methods)。

创建 ADT 时需要使用关键字 AS OBJECT

AS OBJECT(包含于 object_or_under)

创建 Schema 级别的 ADT。此类 ADT 有时称为根 ADT。

attr_and_element_spec

element_spec

指定 ADT 的每个属性。

subprogram_spec

subprogram_spec

声明子过程。

member_or_static

  • MEMBER

    与 ADT 关联的函数或存储过程,被称为成员函数。通常,调用 MEMBER 方法主体中具有一个隐式第一参数,称为 SELF 。该参数表示调用该方法的对象。

  • STATIC

    与 ADT 关联的函数或存储过程。与 MEMBER 方法不同,STATIC 方法没有任何隐式参数。您无法在主体引用 SELF。它们通常的调用形式为 type_name.method()

proc_or_func_spec

指定存储过程或函数的参数和数据类型。如果此子程序不包含存储过程或函数的do,则必须通过CREATE TYPE BODY命令做相应的定义。

如果要创建子类型,则存储过程或函数的名称不能与在超类型链中声明的任何属性的名称(无论是否继承)相同。