av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

Oracle數(shù)據(jù)庫(kù)如何創(chuàng)建對(duì)象類(lèi)型和對(duì)象類(lèi)型表

Oracle數(shù)據(jù)庫(kù)創(chuàng)建對(duì)象類(lèi)型時(shí)與創(chuàng)建表的操作實(shí)際上是類(lèi)似的,只是創(chuàng)建對(duì)象類(lèi)型實(shí)際上不為存儲(chǔ)的數(shù)據(jù)分配空間。此外,對(duì)象類(lèi)型也有屬性和方法。本文我們主要介紹一下Oracle對(duì)象類(lèi)型和對(duì)象類(lèi)型表的一些知識(shí),接下來(lái)我們就開(kāi)始介紹。

讓客戶(hù)滿意是我們工作的目標(biāo),不斷超越客戶(hù)的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶(hù),將通過(guò)不懈努力成為客戶(hù)在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名注冊(cè)、網(wǎng)站空間、營(yíng)銷(xiāo)軟件、網(wǎng)站建設(shè)、定邊網(wǎng)站維護(hù)、網(wǎng)站推廣。

不帶方法的簡(jiǎn)單對(duì)象類(lèi)型:

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

注意:AS OBJECT

創(chuàng)建好對(duì)象類(lèi)型之后,就可以在創(chuàng)建表的時(shí)候,使用該類(lèi)型了,如:

 
 
 
  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.  

稍后,可以用下面的語(yǔ)句查看:

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

此下省去兩個(gè)Trigger.

插入數(shù)據(jù)的時(shí)候,可以如下:

 
 
 
  1. INSERT INTO STUDENTS (STUDENT) VALUES (HUMAN('xling','M',TO_DATE('20060101','YYYYMMDD'),'測(cè)試')) 

注意:HUMAN('xling','M',TO_DATE('20060101','YYYYMMDD'),'測(cè)試'),這是個(gè)默認(rèn)的構(gòu)造函數(shù).

如果想選出性別為女(F)的記錄,可以如下:

 
 
 
  1. SELECT * FROM STUDENTS S WHERE S.STUDENT.SEX = 'F' 

注意:不能寫(xiě)成:SELECT * FROM STUDENTS WHERE STUDENT.SEX = 'F' 這樣會(huì)報(bào)如下錯(cuò)誤:ORA-00904: "STUDENT"."SEX": 標(biāo)識(shí)符無(wú)效

對(duì)象類(lèi)型表:每條記錄都是對(duì)象的表,稱(chēng)為對(duì)象類(lèi)型表.它有兩個(gè)使用方法:1,用作只有一個(gè)對(duì)象類(lèi)型字段的表.2,用作具有對(duì)象類(lèi)型字段的標(biāo)準(zhǔn)關(guān)系表.

語(yǔ)法如下:CREATE TABLE table_name OF object_type;

例如:CREATE TABLE TMP_STUDENTS OF HUMAN;

用DESC TMP_STUDENTS,可以看到它的字段結(jié)構(gòu)和HUMAN的結(jié)構(gòu)一樣.

對(duì)象類(lèi)型表有兩個(gè)優(yōu)點(diǎn):

1,從某種程度上簡(jiǎn)化了對(duì)象的使用,因?yàn)閷?duì)象表的字段類(lèi)型與對(duì)象類(lèi)型是一致的,所以,不需要用對(duì)象名來(lái)修飾對(duì)象屬性,可以把數(shù)據(jù)插入對(duì)象類(lèi)型表,就像插入普通的關(guān)系表中一樣:

 
 
 
  1. INSERT INTO TMP_STUDENTS VALUES ('xling','M',TO_DATE('20060601','YYYYMMDD'),'對(duì)象類(lèi)型表');   
  2.  
  3. INSERT INTO TMP_STUDENTS VALUES (HUMAN('snow','F',TO_DATE('20060102','YYYYMMDD'),'用類(lèi)型的構(gòu)造函數(shù)')); 

第二個(gè)特點(diǎn)是:對(duì)象表是使用對(duì)象類(lèi)型作為模板來(lái)創(chuàng)建表的一種便捷方式,它可以確保多個(gè)表具有相同的結(jié)構(gòu).

對(duì)象類(lèi)型表在:USER_TABLES表里是查不到的,而在USER_OBJECTS表里可以查到,而且OBJECT_TYPE = 'TABLE'

類(lèi)型在定義的時(shí)候,會(huì)自動(dòng)包含一個(gè)方法,即默認(rèn)的構(gòu)造器.構(gòu)造器的名稱(chēng)與對(duì)象的名稱(chēng)相同,它帶有變量與對(duì)象類(lèi)型的每個(gè)屬性相對(duì)應(yīng).

對(duì)象類(lèi)型的方法:

 
 
 
  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,(當(dāng)然,也可是MEMBER PROCEDURE,沒(méi)有返回值)

和包(PACKAGE)一樣,如果對(duì)象類(lèi)型有方法的話,還要聲明一個(gè)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,也不是用小括號(hào)括起來(lái)的.MEMBER FUNCTION 后的AS或IS不能省略.

關(guān)于Oracle對(duì)象類(lèi)型與對(duì)象類(lèi)型表的知識(shí)就介紹到這里了,希望本次的介紹能夠給您帶來(lái)一些收獲,謝謝!

【編輯推薦】

  1. Oracle數(shù)據(jù)庫(kù)的冷備份及冷備份異地恢復(fù)方法
  2. Oracle數(shù)據(jù)庫(kù)如何創(chuàng)建DB Link操作遠(yuǎn)程數(shù)據(jù)庫(kù)
  3. 淺談Oracle與SQL Server對(duì)Update語(yǔ)句的處理
  4. Oracle數(shù)據(jù)庫(kù)如何查看當(dāng)前用戶(hù)角色權(quán)限及默認(rèn)表空間
  5. Oracle XDB與各種App Server默認(rèn)端口沖突問(wèn)題的解決

新聞標(biāo)題:Oracle數(shù)據(jù)庫(kù)如何創(chuàng)建對(duì)象類(lèi)型和對(duì)象類(lèi)型表
網(wǎng)頁(yè)網(wǎng)址:http://uogjgqi.cn/article/dpciheg.html
掃二維碼與項(xiàng)目經(jīng)理溝通

我們?cè)谖⑿派?4小時(shí)期待你的聲音

解答本文疑問(wèn)/技術(shù)咨詢(xún)/運(yùn)營(yíng)咨詢(xún)/技術(shù)建議/互聯(lián)網(wǎng)交流