Oracle數(shù)據(jù)庫如何創(chuàng)建對象類型和對象類型表
Oracle數(shù)據(jù)庫創(chuàng)建對象類型時與創(chuàng)建表的操作實際上是類似的,只是創(chuàng)建對象類型實際上不為存儲的數(shù)據(jù)分配空間。此外,對象類型也有屬性和方法。本文我們主要介紹一下Oracle對象類型和對象類型表的一些知識,接下來我們就開始介紹。
不帶方法的簡單對象類型:
- CREATE TYPE type_name as OBJECT (
- column_1 type1,
- column_2 type2, );
注意:AS OBJECT
創(chuàng)建好對象類型之后,就可以在創(chuàng)建表的時候,使用該類型了,如:
- CREATE TYPE HUMAN AS OBJECT(
- NAME VARCHAR2(20),
- SEX VARCHAR2(1),-- F : FEMALE M:MALE
- BIRTHDAY DATE,
- NOTE VARCHAR2(300)
- )
稍后,可以用下面的語句查看:
- SELECT * FROM USER_OBJECTS WHERE OBJECT_TYPE = 'TYPE' CREATE TABLE STUDENTS(
- GUID NUMBER NOT NULL,
- STUDENTS HUMAN
- )
此下省去兩個Trigger.
插入數(shù)據(jù)的時候,可以如下:
- INSERT INTO STUDENTS (STUDENT) VALUES (HUMAN('xling','M',TO_DATE('20060101','YYYYMMDD'),'測試'))
注意:HUMAN('xling','M',TO_DATE('20060101','YYYYMMDD'),'測試'),這是個默認的構(gòu)造函數(shù).
如果想選出性別為女(F)的記錄,可以如下:
- SELECT * FROM STUDENTS S WHERE S.STUDENT.SEX = 'F'
注意:不能寫成:SELECT * FROM STUDENTS WHERE STUDENT.SEX = 'F' 這樣會報如下錯誤:ORA-00904: "STUDENT"."SEX": 標識符無效
對象類型表:每條記錄都是對象的表,稱為對象類型表.它有兩個使用方法:1,用作只有一個對象類型字段的表.2,用作具有對象類型字段的標準關(guān)系表.
語法如下:CREATE TABLE table_name OF object_type;
例如:CREATE TABLE TMP_STUDENTS OF HUMAN;
用DESC TMP_STUDENTS,可以看到它的字段結(jié)構(gòu)和HUMAN的結(jié)構(gòu)一樣.
對象類型表有兩個優(yōu)點:
1,從某種程度上簡化了對象的使用,因為對象表的字段類型與對象類型是一致的,所以,不需要用對象名來修飾對象屬性,可以把數(shù)據(jù)插入對象類型表,就像插入普通的關(guān)系表中一樣:
- INSERT INTO TMP_STUDENTS VALUES ('xling','M',TO_DATE('20060601','YYYYMMDD'),'對象類型表');
- INSERT INTO TMP_STUDENTS VALUES (HUMAN('snow','F',TO_DATE('20060102','YYYYMMDD'),'用類型的構(gòu)造函數(shù)'));
第二個特點是:對象表是使用對象類型作為模板來創(chuàng)建表的一種便捷方式,它可以確保多個表具有相同的結(jié)構(gòu).
對象類型表在:USER_TABLES表里是查不到的,而在USER_OBJECTS表里可以查到,而且OBJECT_TYPE = 'TABLE'
類型在定義的時候,會自動包含一個方法,即默認的構(gòu)造器.構(gòu)造器的名稱與對象的名稱相同,它帶有變量與對象類型的每個屬性相對應.
對象類型的方法:
- 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不能省略.
關(guān)于Oracle對象類型與對象類型表的知識就介紹到這里了,希望本次的介紹能夠給您帶來一些收獲,謝謝!
【編輯推薦】






