在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美

當前位置:雨林木風下載站 > 應用軟件教程 > 詳細頁面

Oracle數據庫表與視圖

Oracle數據庫表與視圖

更新時間:2025-10-19 文章作者:未知 信息來源:網絡 閱讀次數:

數據庫,簡而言之可視為電子化的文件柜——存儲電子文件的處所,用戶可以對文件中的數據進行新增、截取、更新、刪除等操作。所謂“數據庫”是以一定方式儲存在一起、能與多個用戶共享、具有盡可能小的冗余度、與應...
數據庫,簡而言之可視為電子化的文件柜——存儲電子文件的處所,用戶可以對文件中的數據進行新增、截取、更新、刪除等操作。所謂“數據庫”是以一定方式儲存在一起、能與多個用戶共享、具有盡可能小的冗余度、與應用程序彼此獨立的數據集合。
 Oracle數據庫數據對象中最基本的是表和視圖,其他還有約束、序列、函數、存儲過程、包、觸發器等。對數據庫的操作可以基本歸結為對數據對象的操作,理解和掌握Oracle數據庫對象是學習Oracle的捷徑。
  表和視圖
  Oracle中表是數據存儲的基本結構。ORACLE8引入了分區表和對象表,ORACLE8i引入了臨時表,使表的功能更強大。視圖是一個或多個表中數據的邏輯表達式。本文我們將討論怎樣創建和管理簡單的表和視圖。
  管理表
  表可以看作有行和列的電子數據表,表是關系數據庫中一種擁有數據的結構。用CREATE TABLE語句建立表,在建立表的同時,必須定義表名,列,以及列的數據類型和大小。例如:
    CREATE TABLE products
  ( PROD_ID NUMBER(4),
   PROD_NAME VAECHAR2(20),
   STOCK_QTY NUMBER(5,3)
  ); 
  這樣我們就建立了一個名為products的表, 關鍵詞CREATE TABLE后緊跟的表名,然后定義了三列,同時規定了列的數據類型和大小。
  在創建表的同時你可以規定表的完整性約束,也可以規定列的完整性約束,在列上普通的約束是NOT NULL,關于約束的討論我們在以后進行。
  在建立或更改表時,可以給表一個缺省值。缺省值是在增加行時,增加的數據行中某一項值為null時,oracle即認為該值為缺省值。
  下列數據字典視圖提供表和表的列的信息:
   . DBA_TABLES
   . DBA_ALL_TABLES
   . USER_TABLES
   . USER_ALL_TABLES
   . ALL_TABLES
   . ALL_ALL_TABLES
   . DBA_TAB_COLUMNS
   . USER_TAB_COLUMNS
   . ALL_TAB_COLUMNS
  表的命名規則
  表名標識一個表,所以應盡可能在表名中描述表,oracle中表名或列名最長可以達30個字符串。表名應該以字母開始,可以在表名中包含數字、下劃線、#、$等。
  從其它表中建立表
  可以使用查詢從基于一個或多個表中建立表,表的列的數據類型和大小有查詢結果決定。建立這種形式的表的查詢可以選擇其他表中所有的列或者只選擇部分列。在CREATE TABLE語句中使用關鍵字AS,例如:
SQL>CREATE TABLE emp AS SELECT * FROM employee
TABLE CREATED
SQL> CREATE TABLE Y AS SELECT * FROM X WHERE no=2 
  需要注意的是如果查詢涉及LONG數據類型,那么CREATE TABLE....AS SELECT....將不會工作。
  更改表定義
  在建立表后,有時候我們可能需要修改表,比如更改列的定義,更改缺省值,增加新列,刪除列等等。ORACLE使用ALTER TABLE語句來更改表的定義
  1、增加列
  語法:
ALTER TABLE [schema.] table_name ADD column_definition 
  例:
ALTER TABLE orders ADD order_date DATE;
TABLE ALTER 
  對于已經存在的數據行,新列的值將是NULL.
  2、更改列
  語法:
ALTER TABLE [schema.] table_name MODIFY column_name new_attributes; 
  例:
ALTER TABLE orders MODITY (quantity number(10,3),status varchar2(15)); 
  這個例子中我們修改了表orders,將STATUS列的長度增加到15,將QUANTITY列減小到10,3;
  修改列的規則如下:
   . 可以增加字符串數據類型的列的長度,數字數據類型列的精度。
   . 減少列的長度時,該列應該不包含任何值,所有數據行都為NULL.
   . 改變數據類型時,該列的值必須是NULL.
   . 對于十進制數字,可以增加或減少但不能降低他的精度。
[page_break] 3、刪除數據列
  優化ORACLE數據庫,唯一的方法是刪除列,重新建立數據庫。在ORACLE8i中有很多方法刪除列,你可以刪除未用數據列或者可以標示該列為未用數據列然后刪除。
  刪除數據列的語法是:
ALTER TABLE [schema.] table_name DROP {COLUM column_names | (column_names)}[CASCADE CONSTRAINS] 
  要注意的是在刪除列時關于該列的索引和完整性約束也同時刪除。注意關鍵字CASCADE CONSTRAINS,如果刪除的列是多列約束的一部分,那么這個約束條件相對于其他列也同時刪除。
  如果用戶擔心在大型數據庫中刪除列要花太多時間,可以先將他們標記為未用數據列,標記未用數據列的語法如下:
ALTER TABLE [schema.] table_name SET UNUSED {COLUM column_names | (column_names)}[CASCADE CONSTRAINS] 
  這個語句將一個或多個數據列標記為未用數據列,但并不刪除數據列中的數據,也不釋放占用的磁盤空間。但是,未用數據列在視圖和數據字典中并不顯示,并且該數據列的名稱將被刪除,新的數據列可以使用這個名稱。基于該數據列的索引、約束,統計等都將被刪除。
  刪除未用數據列的語句是:
ALTER TABLE [schema.] table_name DROP {UNUSED COLUM | COLUMN CONTINUE} 
刪除表和更改表名
  刪除表非常簡單,但它是一個不可逆轉的行為。
  語法:
DROP TABLE [schema.] table_name [CASCADE CONSTRAINTS] 
  
  刪除表后,表上的索引、觸發器、權限、完整性約束也同時刪除。ORACLE不能刪除視圖,或其他程序單元,但oracle將標示他們無效。如果刪除的表涉及引用主鍵或唯一關鍵字的完整性約束時,那么DROP TABLE語句就必須包含CASCADE CONSTRAINTS子串。
  更改表名
  RENAME命令用于給表和其他數據庫對象改名。ORACLE系統自動將基于舊表的完整性約束、索引、權限轉移到新表中。ORACLE同時使所有基于舊表的數據庫對象,比如視圖、程序、函數等,為不合法。
  語法:
RENAME old_name TO new_name; 
  例:
SQL> RENAME orders TO purchase_orders;
TABLE RENAMED
 
  截短表
  TRUNCATE命令與DROP命令相似, 但他不是刪除整個數據表,所以索引、完整性約束、觸發器、權限等都不會被刪除。缺省情況下將釋放部分表和視圖空間,如果用戶不希望釋放表空間,TRUNCATE語句中要包含REUSE STORAGE子串。TRUNCATE命令語法如下:
TRUNCATE {TABLE|CLUSTER} [schema.] name {DROP|REUSE STORAGE} 
  例:
SQL> TRUNCATE TABLE t1;
TABLE truncate. 
  管理視圖
  視圖是一個或多個表中的數據的簡化描述,用戶可以將視圖看成一個存儲查詢(stored query)或一個虛擬表(virtual table).查詢僅僅存儲在oracle數據字典中,實際的數據沒有存放在任何其它地方,所以建立視圖不用消耗其他的空間。視圖也可以隱藏復雜查詢,比如多表查詢,但用戶只能看見視圖。視圖可以有與他所基于表的列名不同的列名。用戶可以建立限制其他用戶訪問的視圖。
  建立視圖
  CREATE VIEW命令創建視圖,定義視圖的查詢可以建立在一個或多個表,或其他視圖上。查詢不能有FOR UPDATE子串,在早期的ORACLE8i版本中不支持ORDER BY子串,現在的版本中CREATE VIEW可以擁有ORDER BY子串。
  例:
SQL> CREATE VIEW TOP_EMP AS 
SELECT empno EMPLOYEE_ID,ename EMPLOYEE_NAME,salary 
FROM emp
WHERE salary >2000 
  用戶可以在創建視圖的同時更改列名,方法是在視圖名后立即加上要命名的列名。重新定義視圖需要包含OR REPLACE子串。
SQL> CREATE VIEW TOP_EMP
(EMPLOYEE_ID,EMPLOYEE_NAME,SALARY) AS 
SELECT empno ,ename ,salary 
FROM emp
WHERE salary >2000 
  如果在創建的視圖包含錯誤在正常情況下,視圖將不會被創建。但如果你需要創建一個帶錯誤的視圖必須在CREATE VIEW語句中帶上FORCE選項。如:
CREATE FORCE VIEW ORDER_STATUS AS 
SELECT * FROM PURCHASE_ORDERS
WHERE STATUS=’APPPOVE’;
SQL>/
warning :View create with compilation errors 
  這樣將創建了一個名為ORDER_STATUS的視圖,但這樣的視圖的狀態是不合法的,如果以后狀態發生變化則可以重新編譯,其狀態也變成合法的。
  從視圖中獲得數據
  從視圖中獲得數據與從表中獲得數據基本一樣,用戶可以在連接和子查詢中使用視圖,也可以使用SQL函數,以及所有SELECT語句的字串。
  插入、更新、刪除數據
  用戶在一定的限制條件下可以通過視圖更新、插入、刪除數據。如果視圖連接多個表,那么在一個時間里只能更新一個表。所有的能被更新的列可以在數據字典USER_UPDATETABLE_COLUMNS中查到。
  用戶在CREATE VIEW中可以使用了WITH子串。WITH READ ONLY子串表示創建的視圖是一個只讀視圖,不能進行更新、插入、刪除操作。WITH CHECK OPTION表示可以進行插入和更新操作,但應該滿足WHERE子串的條件。這個條件就是創建視圖WHERE子句的條件,比如在上面的例子中用戶創建了一個視圖TOP_EMP,在這個視圖中用戶不能插入salary小于2000的數據行。
  刪除視圖
  刪除視圖使用DROP VIEW命令。同時將視圖定義從數據字典中刪除,基于視圖的權限也同時被刪除,其他涉及到該視圖的函數、視圖、程序等都將被視為非法。

全新的路由器不僅讓你更穩定快速地連接無線網絡,更可以讓家中的智能設備連接在一起。

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美
  • <li id="86scu"><menu id="86scu"></menu></li>
    <li id="86scu"></li>
    <button id="86scu"></button>
  • <s id="86scu"></s><button id="86scu"><menu id="86scu"></menu></button>
  • 久久美女福利视频| 国产福利影院在线观看| 中文国产在线观看| 免费看涩涩视频| 黄色三级视频片| 天天操天天爱天天爽| 999精品视频在线| 天堂网在线免费观看| 天天爽人人爽夜夜爽| 国产原创精品在线| 天天摸天天舔天天操| 福利视频999| 欧美爱爱视频网站| 九九久久九九久久| 18岁网站在线观看| 亚洲高清在线免费观看| 五月天av在线播放| 国产树林野战在线播放| 免费极品av一视觉盛宴| 免费在线观看视频a| 色综合久久久久无码专区| 爱福利视频一区二区| 在线观看免费污视频| 天天色天天干天天色| 成人短视频在线观看免费| 日韩av在线播放不卡| 99草草国产熟女视频在线| 久久久久久久久久一区| 毛片av在线播放| 日韩 欧美 高清| www.桃色.com| 日本少妇高潮喷水视频| 福利视频999| 日韩精品―中文字幕| 一级片视频免费观看| 精品成在人线av无码免费看| 国产精品igao| 996这里只有精品| 91淫黄看大片| 免费毛片网站在线观看| 国产亚洲视频一区| 久久久亚洲国产精品| 五月天婷婷影视| 精品人妻一区二区三区四区在线| 亚洲天堂伊人网| 最近免费中文字幕中文高清百度| 亚洲av首页在线| 欧美wwwwwww| 男人亚洲天堂网| 欧美高清中文字幕| 黄色一级片免费播放| 日本一道本久久| 69精品丰满人妻无码视频a片| 青青在线免费观看视频| 免费一级特黄毛片| 国产日韩第一页| 日本黄色的视频| 无需播放器的av| 9久久婷婷国产综合精品性色 | 国产人妻互换一区二区| 午夜免费高清视频| 女人扒开屁股爽桶30分钟| 妞干网视频在线观看| 最近中文字幕免费mv| 亚洲午夜激情影院| 一级黄色在线播放| 午夜xxxxx| 91视频福利网| 神马午夜伦理影院| 男人添女人下部视频免费| 99亚洲国产精品| 欧美一级特黄aaaaaa在线看片| 91免费视频污| 最新av网址在线观看| 日本精品免费视频| 欧美一级免费在线| 国产免费xxx| 免费看欧美黑人毛片| 日本午夜激情视频| 日本精品一区二区三区四区| 缅甸午夜性猛交xxxx| 国内自拍在线观看| 日本www.色| 交换做爰国语对白| 国产精品国产对白熟妇| 日韩少妇内射免费播放| 老司机午夜av| 五月天丁香花婷婷| 五十路熟女丰满大屁股| 99久久久无码国产精品6| 日本肉体xxxx裸体xxx免费| 日本中文字幕观看| 日韩av新片网| 午夜视频你懂的| 国产欧美综合一区| 91视频最新入口| 国产精品自在自线| 怡红院av亚洲一区二区三区h| 国产视频在线视频| 国产精品视频网站在线观看| 2022亚洲天堂| 亚洲精品天堂成人片av在线播放| 一女被多男玩喷潮视频| 五月激情婷婷在线| 97超碰青青草| 熟妇熟女乱妇乱女网站| 亚洲乱码中文字幕久久孕妇黑人| www.桃色.com| 老司机午夜av| 亚洲熟妇av日韩熟妇在线| 亚洲最新免费视频| 日本特黄在线观看| 91小视频网站| 少妇高清精品毛片在线视频| 九九久久九九久久| 国产麻豆电影在线观看| 天天插天天操天天射| 99999精品视频| 欧美人成在线观看| 裸体裸乳免费看| 亚洲一区二区三区观看| 午夜视频在线瓜伦| 国产中文字幕视频在线观看| 中文字幕日韩精品无码内射| 国内自拍第二页| 波多野结衣国产精品| 欧美精品久久久久久久久25p| 久久久久人妻精品一区三寸| av久久久久久| 国产九色porny| 久久久99精品视频| 波多野结衣 作品| 青青草影院在线观看| www.久久久久久久久久久| 亚洲一区在线不卡| www.夜夜爽| 亚洲制服中文字幕| 青娱乐国产精品视频| 中文字幕第66页| 最新中文字幕久久| 欧美少妇在线观看| 免费一级特黄毛片| 精品一区二区中文字幕| 国产第一页视频| jizz欧美激情18| 国产免费中文字幕| 99久久99久久精品| 成人免费毛片在线观看| 欧美韩国日本在线| 九九热99视频| 成人在线观看毛片| 能在线观看的av| 岛国av在线免费| 亚洲一区 在线播放| 日韩免费一级视频| 亚洲欧美久久久久| 欧美人与动牲交xxxxbbbb| 六月丁香激情网| 污污网站免费看| 日本三级中文字幕在线观看| 97成人在线免费视频| 亚洲色精品三区二区一区| 久久久国产精华液999999 | 日韩欧美精品免费| 日韩一级在线免费观看| 亚洲免费视频播放| 国产h视频在线播放| 思思久久精品视频| av动漫在线看| 福利网在线观看| 成年人在线看片| 青青视频免费在线| 亚洲福利精品视频| 人妻少妇精品无码专区二区| 小明看看成人免费视频| 妞干网在线观看视频| 欧美一级特黄aaa| a在线视频观看| 黄色一级大片免费| 99精品视频国产| 丁香婷婷激情网| 免费在线观看亚洲视频| 91精品一区二区三区四区| 丝袜制服一区二区三区| 日本网站免费在线观看| 99精品一区二区三区的区别| 中文字幕网av| 粗暴91大变态调教| 99精品在线免费视频| 僵尸世界大战2 在线播放| 手机看片日韩国产| 99re6在线观看| 亚洲 国产 图片| 国产区二区三区| 91精品无人成人www| 茄子视频成人免费观看| 波多野结衣综合网| 婷婷无套内射影院| 霍思燕三级露全乳照| 国产玉足脚交久久欧美|