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

数据库 Oracle
本文我们主要介绍了Oracle对象类型和对象类型表的一些操作,并给出了详细的代码示例,说明以及注意事项,希望能够对您有所帮助。

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

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

 

  1. CREATE TYPE type_name as OBJECT (  
  2.  
  3. column_1 type1,  
  4.  
  5. column_2 type2, ); 

 

注意:AS OBJECT

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

 

  1. CREATE TYPE HUMAN AS OBJECT(  
  2.  
  3. NAME VARCHAR2(20),  
  4.  
  5. SEX VARCHAR2(1),-- F : FEMALE M:MALE   
  6.  
  7. BIRTHDAY DATE,  
  8.  
  9. NOTE VARCHAR2(300)  
  10.  

 

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

 

  1. SELECT * FROM USER_OBJECTS WHERE OBJECT_TYPE = 'TYPE' CREATE TABLE STUDENTS(  
  2.  
  3. GUID NUMBER NOT NULL,  
  4.  
  5. STUDENTS HUMAN  
  6.  

 

此下省去两个Trigger.

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

 

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

 

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

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

 

  1. SELECT * FROM STUDENTS S WHERE S.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,从某种程度上简化了对象的使用,因为对象表的字段类型与对象类型是一致的,所以,不需要用对象名来修饰对象属性,可以把数据插入对象类型表,就像插入普通的关系表中一样:

 

  1. INSERT INTO TMP_STUDENTS VALUES ('xling','M',TO_DATE('20060601','YYYYMMDD'),'对象类型表');   
  2.  
  3. INSERT INTO TMP_STUDENTS VALUES (HUMAN('snow','F',TO_DATE('20060102','YYYYMMDD'),'用类型的构造函数')); 

 

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

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

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

对象类型的方法:

 

  1. CREATE TYPE type_name AS OBJECT (  
  2.  
  3. column1 column_type1,  
  4.  
  5. column2 column_type2,  
  6.  
  7. ... ,  
  8.  
  9. MEMBER FUNCTION method_name(args_list) RETURN return_type, ) 

 

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

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

 

  1. CREATE TYPE BODY type_name AS MEMBER FUNCTION method_name RETURN return_type {AS | IS}  
  2.  
  3. variable declareations..  
  4.  
  5. BEGIN  
  6.  
  7. CODE..  
  8.  
  9. RETURN return_value;  
  10.  
  11. END;//END MEMBER FUNCTION END;//END TYPE BODY 

 

如下所示:

 

  1. CREATE TYPE HUMAN AS OBJECT(  
  2.  
  3. NAME VARCHAR2(20),  
  4.  
  5. SEX VARCHAR2(1),-- F : FEMALE M:MALE   
  6.  
  7. BIRTHDAY DATE,  
  8.  
  9. NOTE VARCHAR2(300),   
  10.  
  11. MEMBER FUNCTION GET_AGE RETURN NUMBER  
  12.  
  13. )  
  14.  
  15. --BODY   
  16.  
  17. CREATE TYPE BODY HUMAN AS  
  18.  
  19. MEMBER FUNCTION GET_AGE RETURN NUMBER AS  
  20.  
  21. V_MONTHS NUMBER;  
  22.  
  23. BEGIN  
  24.  
  25. SELECT FLOOR(MONTHS_BETWEEN(SYSDATE,BIRTHDAY)/12) INTO V_MONTHS FROM DUAL;  
  26.  
  27. RETURN V_MONTHS;  
  28.  
  29. END;   
  30.  
  31. END; 

 

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

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

【编辑推荐】

  1. Oracle数据库的冷备份及冷备份异地恢复方法
  2. Oracle数据库如何创建DB Link操作远程数据库
  3. 浅谈Oracle与SQL Server对Update语句的处理
  4. Oracle数据库如何查看当前用户角色权限及默认表空间
  5. Oracle XDB与各种App Server默认端口冲突问题的解决
责任编辑:赵鹏 来源: 火魔网
相关推荐

2023-09-06 09:01:38

Oracle数据库

2009-11-03 10:14:41

Oracle数据库对象

2015-07-23 17:02:55

oracle创建数据库

2022-04-17 10:29:10

TSTypeScript对象类型

2010-04-14 09:54:56

Oracle数据库

2011-08-09 14:54:01

OracleDATABASE LI

2010-04-23 16:05:50

Oracle数据库

2010-04-22 09:42:00

2010-03-30 17:40:59

Oracle数据库

2011-08-02 17:06:29

Oracle远程数据库创建DB Link

2010-04-14 10:12:07

Oracle数据库

2019-11-29 07:37:44

Oracle数据库索引

2021-09-28 09:25:05

NoSQL数据库列式数据库

2011-07-04 09:12:53

数据库采购

2011-08-04 11:00:35

Oracle数据库虚拟列复合触发器

2011-04-11 13:19:41

Oracle数据库

2010-04-12 16:35:15

Oracle数据库

2011-07-29 10:36:43

游标Oracle数据库

2009-09-01 10:58:46

C#匿名类型对象

2021-01-18 08:52:28

Java对象多态
点赞
收藏

51CTO技术栈公众号