成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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默認端口沖突問題的解決
責任編輯:趙鵬 來源: 火魔網
相關推薦

2009-11-03 10:14:41

Oracle數據庫對象

2023-09-06 09:01:38

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-03-30 17:40:59

Oracle數據庫

2010-04-22 09:42:00

2010-04-23 16:05:50

Oracle數據庫

2011-08-02 17:06:29

Oracle遠程數據庫創建DB Link

2010-04-14 10:12:07

Oracle數據庫

2025-03-27 07:30:28

2019-11-29 07:37:44

Oracle數據庫索引

2021-09-28 09:25:05

NoSQL數據庫列式數據庫

2011-04-11 13:19:41

Oracle數據庫

2011-07-04 09:12:53

數據庫采購

2011-08-04 11:00:35

Oracle數據庫虛擬列復合觸發器

2009-11-10 11:22:11

Visual Stud

2011-03-16 17:26:22

動態數據庫

2010-04-12 16:35:15

Oracle數據庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国精产品一区一区三区免费完 | 九九久久国产 | 在线观看国产 | 午夜电影合集 | 欧美一区不卡 | 亚洲国产精品美女 | 中文字幕免费 | 影音先锋久久 | 亚洲精品久久久久久下一站 | 日韩在线欧美 | 精品无码久久久久久国产 | 国产视频日韩 | 欧美性受xxxx | 成人免费观看网站 | 欧美成年网站 | 国产精品 欧美精品 | 成人一区二区三区在线观看 | 亚洲综合大片69999 | 一级毛片视频 | 久久久久九九九女人毛片 | 国产精品久久久久无码av | av网站在线播放 | 亚洲一区二区视频在线播放 | 久久爱黑人激情av摘花 | 麻豆久久久久久久 | 国产精品一区二区三区久久久 | 国产一区 | 找个黄色片 | 91精品国产91久久久久久最新 | 中文字幕精品一区久久久久 | 欧美日韩三级 | 久久久高清 | 免费在线观看成年人视频 | 少妇特黄a一区二区三区88av | 在线免费观看日本视频 | 在线观看黄色大片 | 久久久噜噜噜久久中文字幕色伊伊 | 91精品国产自产精品男人的天堂 | 亚洲黄色av网站 | 91tv在线观看 | 蜜臀久久99精品久久久久野外 |