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
格式为:plsql_type_spec_source
格式为:object_type_def
格式为:attr_and_element_spec
格式为:element_spec
格式为:el_element_spec_list_cc
格式为:element_spec_long
格式为:inheritance_final_instantiable_clause
格式为:inheritance_overriding_instantiable_clause
格式为:subprogram_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 | 创建一个类型的嵌套表,命名为 | |
object_type_def | object_type_def | 创建一个 ADT。形成数据结构的变量称为属性(Attributes)。定义 ADT 行为的成员子程序称为方法(Methods)。 创建 ADT 时需要使用关键字 |
AS OBJECT(包含于 object_or_under) | 创建 Schema 级别的 ADT。此类 ADT 有时称为根 ADT。 | |
attr_and_element_spec | element_spec | 指定 ADT 的每个属性。 |
subprogram_spec | subprogram_spec | 声明子过程。 |
member_or_static |
| |
proc_or_func_spec | 指定存储过程或函数的参数和数据类型。如果此子程序不包含存储过程或函数的do,则必须通过 如果要创建子类型,则存储过程或函数的名称不能与在超类型链中声明的任何属性的名称(无论是否继承)相同。 |