oracle创建数据库对象,Oracle数据库如何创建对象类型和对象类型表

Oracle数据库创建对象类型时与创建表的操作实际上是类似的,只是创建对象类型实际上不为存储的数据分配空间。此外,对象类型也有属性和方法。本文我们主要介绍一下Oracle对象类型和对象类型表的一些知识,接下来我们就开始介绍。

不带方法的简单对象类型:

CREATE TYPE type_name as OBJECT (

column_1 type1,

column_2 type2, );

注意:AS OBJECT

创建好对象类型之后,就可以在创建表的时候,使用该类型了,如:

CREATE TYPE HUMAN AS OBJECT(

NAME VARCHAR2(20),

SEX VARCHAR2(1),-- F : FEMALE M:MALE

BIRTHDAY DATE,

NOTE VARCHAR2(300)

)

稍后,可以用下面的语句查看:

SELECT * FROM USER_OBJECTS WHEREOBJECT_TYPE='TYPE'CREATE TABLE STUDENTS(

GUID NUMBER NOT NULL,

STUDENTS HUMAN

)

此下省去两个Trigger.

插入数据的时候,可以如下:

INSERT INTO STUDENTS (STUDENT) VALUES (HUMAN('xling','M',TO_DATE('20060101','YYYYMMDD'),'测试'))

注意:HUMAN('xling','M',TO_DATE('20060101','YYYYMMDD'),'测试'),这是个默认的构造函数.

如果想选出性别为女(F)的记录,可以如下:

SELECT * FROM STUDENTS S WHERES.STUDENT.SEX='F'

注意:不能写成:SELECT * FROM STUDENTS WHERE STUDENT.SEX = 'F' 这样会报如下错误:ORA-00904: "STUDENT"."SEX": 标识符无效

对象类型表:每条记录都是对象的表,称为对象类型表.它有两个使用方法:1,用作只有一个对象类型字段的表.2,用作具有对象类型字段的标准关系表.

语法如下:CREATE TABLE table_name OF object_type;

例如:CREATE TABLE TMP_STUDENTS OF HUMAN;

用DESC TMP_STUDENTS,可以看到它的字段结构和HUMAN的结构一样.

对象类型表有两个优点:

1,从某种程度上简化了对象的使用,因为对象表的字段类型与对象类型是一致的,所以,不需要用对象名来修饰对象属性,可以把数据插入对象类型表,就像插入普通的关系表中一样:

INSERT INTO TMP_STUDENTS VALUES ('xling','M',TO_DATE('20060601','YYYYMMDD'),'对象类型表');

INSERT INTO TMP_STUDENTS VALUES (HUMAN('snow','F',TO_DATE('20060102','YYYYMMDD'),'用类型的构造函数'));

第二个特点是:对象表是使用对象类型作为模板来创建表的一种便捷方式,它可以确保多个表具有相同的结构.

对象类型表在:USER_TABLES表里是查不到的,而在USER_OBJECTS表里可以查到,而且OBJECT_TYPE = 'TABLE'

类型在定义的时候,会自动包含一个方法,即默认的构造器.构造器的名称与对象的名称相同,它带有变量与对象类型的每个属性相对应.

对象类型的方法:

CREATE TYPE type_name AS OBJECT (

column1 column_type1,

column2 column_type2,

... ,

MEMBER FUNCTION method_name(args_list) RETURN return_type, )

注意:是MEMBER FUNCTION,(当然,也可是MEMBER PROCEDURE,没有返回值)

和包(PACKAGE)一样,如果对象类型有方法的话,还要声明一个BODY:

CREATE TYPE BODY type_name AS MEMBER FUNCTION method_name RETURN return_type {AS | IS}

variable declareations..

BEGIN

CODE..

RETURN return_value;

END;//END MEMBER FUNCTION END;//END TYPE BODY

如下所示:

CREATE TYPE HUMAN AS OBJECT(

NAME VARCHAR2(20),

SEX VARCHAR2(1),-- F : FEMALE M:MALE

BIRTHDAY DATE,

NOTE VARCHAR2(300),

MEMBER FUNCTION GET_AGE RETURN NUMBER

)

--BODY

CREATE TYPE BODY HUMAN AS

MEMBER FUNCTION GET_AGE RETURN NUMBER AS

V_MONTHS NUMBER;

BEGIN

SELECT FLOOR(MONTHS_BETWEEN(SYSDATE,BIRTHDAY)/12) INTO V_MONTHS FROM DUAL;

RETURN V_MONTHS;

END;

END;

注意:BODY的格式,不是AS OBJECT,也不是用小括号括起来的.MEMBER FUNCTION 后的AS或IS不能省略.

关于Oracle对象类型与对象类型表的知识就介绍到这里了,希望本次的介绍能够给您带来一些收获,谢谢!

【编辑推荐】

【责任编辑:赵鹏 TEL:(010)68476606】

点赞 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值