以下的文章主要介紹的是作為一名新手的Oracle學習者,應注意的事項,其實想要學好Oracle並不難,只要掌握好其主要的學習構架與相關的注意事項即可,以下的文章主要是對 Oracle注意事項的描述。
1.Oracle 注意事項: 刪除表的注意事項
在刪除一個表中的全部數據時,須使用TRUNCATE TABLE 表名;因為用DROP TABLE,DELETE * FROM 表名時,TABLESPACE表空間該表的占用空間並未釋放,反復幾次DROP,DELETE操作後,該TABLESPACE上百兆的空間就被耗光了。
2.having 子句的用法
having 子句對 group by 子句所確定的行組進行控制,having 子句條件中只允許涉及常量,聚組函數或group by 子句中的列.
3.外部聯接"+"的用法
外部聯接"+"按其在"="的左邊或右邊分左聯接和右聯接.若不帶"+"運算符的表中的一個行不直接匹配於帶"+"預算符的表中的任何行,則前者的行與後者中的一個空行相匹配並被返回.若二者均不帶’+’,則二者中無法匹配的均被返回.利用外部聯接"+",可以替代效率十分低下的 not in 運算,大大提高運行速度.例如,下面這條命令執行起來很慢
用外聯接提高表連接的查詢速度
在作表連接(常用於視圖)時,常使用以下方法來查詢數據:
- SELECT PAY_NO, PROJECT_NAME
- FROM A
- WHERE A.PAY_NO NOT IN (SELECT PAY_
- NO FROM B WHERE VALUE >=120000);
但是若表A有10000條記錄,表B有10000條記錄,則要用掉30分鐘才能查完,主要因為NOT IN要進行一條一條的比較,共需要10000*10000次比較後,才能得到結果。該用外聯接後,可以縮短到1分左右的