Oracle---常用SQL語法和數據對象


1.INSERT  (往數據表里插入記錄的語句)

INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……); 
INSERT INTO 表名(字段名1, 字段名2, ……)  SELECT 字段名1, 字段名2, …… FROM 另外的表名;

字符串類型的字段值必須用單引號括起來, 例如: ’GOOD DAY’
如果字段值里包含單引號’ 需要進行字符串轉換, 我們把它替換成兩個單引號''. 
字符串類型的字段值超過定義的長度會出錯, 最好在插入前進行長度校驗.

日期字段的字段值可以用當前數據庫的系統時間SYSDATE, 精確到秒
或者用字符串轉換成日期型函數TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)
TO_DATE()還有很多種日期格式, 可以參看ORACLE DOC. 
年-月-日 小時:分鍾:秒 的格式YYYY-MM-DD HH24:MI:SS

INSERT時最大可操作的字符串長度小於等於4000個單字節, 如果要插入更長的字符串, 請考慮字段用CLOB類型,
方法借用ORACLE里自帶的DBMS_LOB程序包.

INSERT時如果要用到從1開始自動增長的序列號, 應該先建立一個序列號
CREATE SEQUENCE 序列號的名稱 (最好是表名+序列號標記) INCREMENT BY 1  START  WITH  1 
 MAXVALUE  99999  CYCLE  NOCACHE;
其中最大的值按字段的長度來定, 如果定義的自動增長的序列號 NUMBER(6) , 最大值為999999
INSERT 語句插入這個字段值為: 序列號的名稱.NEXTVAL


2.DELETE  (刪除數據表里記錄的語句)

DELETE FROM表名 WHERE 條件;

注意:刪除記錄並不能釋放ORACLE里被占用的數據塊表空間. 它只把那些被刪除的數據塊標成unused.

如果確實要刪除一個大表里的全部記錄, 可以用 TRUNCATE 命令, 它可以釋放占用的數據塊表空間
TRUNCATE TABLE 表名; 
此操作不可回退.

------------------------------------------------------------------
3.UPDATE  (修改數據表里記錄的語句)

UPDATE表名 SET 字段名1=值1, 字段名2=值2, …… WHERE 條件;

如果修改的值N沒有賦值或定義時, 將把原來的記錄內容清為NULL, 最好在修改前進行非空校驗; 
值N超過定義的長度會出錯, 最好在插入前進行長度校驗..

------------------------------------------------------------------
注意事項: 
A.    以上SQL語句對表都加上了行級鎖,
    確認完成后, 必須加上事物處理結束的命令 COMMIT 才能正式生效, 
    否則改變不一定寫入數據庫里.    
    如果想撤回這些操作, 可以用命令 ROLLBACK 復原.
    
B.    在運行INSERT, DELETE 和 UPDATE 語句前最好估算一下可能操作的記錄范圍, 
    應該把它限定在較小 (一萬條記錄) 范圍內,. 否則ORACLE處理這個事物用到很大的回退段. 
    程序響應慢甚至失去響應. 如果記錄數上十萬以上這些操作, 可以把這些SQL語句分段分次完成, 
    其間加上COMMIT 確認事物處理.

======================================
二.數據定義 (DDL) 部分
======================================

1.CREATE (創建表, 索引, 視圖, 同義詞, 過程, 函數, 數據庫鏈接等)

ORACLE常用的字段類型有
CHAR            固定長度的字符串
VARCHAR2        可變長度的字符串
NUMBER(M,N)        數字型M是位數總長度, N是小數的長度
DATE            日期類型

創建表時要把較小的不為空的字段放在前面, 可能為空的字段放在后面

創建表時可以用中文的字段名, 但最好還是用英文的字段名

創建表時可以給字段加上默認值, 例如 DEFAULT SYSDATE
這樣每次插入和修改時, 不用程序操作這個字段都能得到動作的時間

創建表時可以給字段加上約束條件
例如 不允許重復 UNIQUE, 關鍵字 PRIMARY KEY

------------------------------------------------------------------        
2.ALTER    (改變表, 索引, 視圖等)

改變表的名稱
ALTER TABLE 表名1  TO 表名2;

在表的后面增加一個字段
ALTER TABLE表名 ADD 字段名 字段名描述;

修改表里字段的定義描述
ALTER TABLE表名 MODIFY字段名 字段名描述;

給表里的字段加上約束條件
ALTER TABLE 表名 ADD CONSTRAINT 約束名 PRIMARY KEY (字段名);
ALTER TABLE 表名 ADD CONSTRAINT 約束名 UNIQUE (字段名);

把表放在或取出數據庫的內存區
ALTER TABLE 表名 CACHE;
ALTER TABLE 表名 NOCACHE;

------------------------------------------------------------------
3.DROP    (刪除表, 索引, 視圖, 同義詞, 過程, 函數, 數據庫鏈接等)

刪除表和它所有的約束條件
DROP TABLE 表名 CASCADE CONSTRAINTS;

------------------------------------------------------------------
4.TRUNCATE (清空表里的所有記錄, 保留表的結構)

TRUNCATE 表名;

=====================================
            三.查詢語句 (SELECT) 部分
=====================================

SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 條件; 

字段名可以帶入函數
  例如:  COUNT(*), MIN(字段名),  MAX(字段名),  AVG(字段名), DISTINCT(字段名), 
       TO_CHAR(DATE字段名,'YYYY-MM-DD HH24:MI:SS')
---------------------------------------------------------------
NVL(EXPR1, EXPR2)函數
解釋:    
IF EXPR1=NULL
        RETURN EXPR2
ELSE
               RETURN EXPR1
---------------------------------------------------------------
DECODE(AA﹐V1﹐R1﹐V2﹐R2.)函數
解釋: 
IF AA=V1 THEN RETURN R1
IF AA=V2 THEN RETURN R2
..…
ELSE
RETURN NULL
---------------------------------------------------------------
LPAD(char1,n,char2)函數
解釋:
字符char1按制定的位數n顯示,不足的位數用char2字符串替換左邊的空位
---------------------------------------------------------------
字段名之間可以進行算術運算
例如:  (字段名1*字段名1)/3
---------------------------------------------------------------

查詢語句可以嵌套
例如: SELECT …… FROM 
(SELECT …… FROM表名1, [表名2, ……] WHERE 條件) WHERE 條件2;
---------------------------------------------------------------
兩個查詢語句的結果可以做集合操作
例如: 並集  UNION    (去掉重復記錄), 
      並集  UNION ALL(不去掉重復記錄), 
      差集  MINUS,  
      交集  INTERSECT

----------------------------------------------------------------
分組查詢
SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] GROUP BY字段名1 
[HAVING 條件] ;

兩個以上表之間的連接查詢

SELECT 字段名1, 字段名2, …… 
FROM   表名1, [表名2, ……] 
WHERE 表名1.字段名 = 表名2. 字段名 
[ AND ……] ;

SELECT字段名1, 字段名2, …… 
FROM  表名1, [表名2, ……] 
WHERE 表名1.字段名 = 表名2. 字段名(+) 
[ AND ……] ;

有(+)號的字段位置自動補空值
----------------------------------------------------------        
查詢結果集的排序操作, 默認的排序是升序ASC, 降序是DESC

SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] 
ORDER BY字段名1, 字段名2 DESC;
----------------------------------------------------------
字符串模糊比較的方法

INSTR(字段名, ‘字符串’)>0    
字段名 LIKE  ‘字符串%’  [‘%字符串%’]

每個表都有一個隱含的字段ROWID, 它標記着記錄的唯一性. 


四.ORACLE里常用的數據對象 (SCHEMA)


1.索引 (INDEX)

CREATE INDEX 索引名ON 表名 ( 字段1, [字段2, ……] );
ALTER INDEX 索引名 REBUILD;

一個表的索引最好不要超過三個 (特殊的大表除外), 最好用單字段索引, 結合SQL語句的分析執行情況, 
也可以建立多字段的組合索引和基於函數的索引

ORACLE8.1.7字符串可以索引的最大長度為1578 單字節
ORACLE8.0.6字符串可以索引的最大長度為758 單字節

ORACLE DOC上說字符串最大可以建索引的長度約是:數據塊的大小(db_block_size)*40%

----------------------------------------------------------------
2.視圖 (VIEW)

CREATE VIEW 視圖名AS SELECT …. FROM …..;
ALTER VIEW視圖名 COMPILE;

視圖僅是一個SQL查詢語句, 它可以把表之間復雜的關系簡潔化.

----------------------------------------------------------------
3.同義詞 (SYNONMY)
CREATE SYNONYM同義詞名FOR 表名;
CREATE SYNONYM同義詞名FOR 表名@數據庫鏈接名;

----------------------------------------------------------------
4.數據庫鏈接 (DATABASE LINK)
CREATE DATABASE LINK數據庫鏈接名CONNECT TO 用戶名 IDENTIFIED BY 密碼 USING ‘數據庫連接字符串’;
    
數據庫連接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定義.

數據庫參數global_name=true時要求數據庫鏈接名稱跟遠端數據庫名稱一樣

數據庫全局名稱可以用以下命令查出
SELECT * FROM GLOBAL_NAME;

查詢遠端數據庫里的表
SELECT …… FROM 表名@數據庫鏈接名;

=====================================
 五.權限管理 (DCL) 語句
=====================================

1.GRANT    賦於權限
常用的系統權限集合有以下三個:
CONNECT(基本的連接), RESOURCE(程序開發), DBA(數據庫管理)
常用的數據對象權限有以下五個:
ALL     ON 數據對象名,     SELECT ON 數據對象名,     UPDATE ON 數據對象名,
DELETE     ON 數據對象名,  INSERT ON 數據對象名,   ALTER  ON 數據對象名

GRANT CONNECT, RESOURCE TO 用戶名;
GRANT SELECT ON 表名 TO 用戶名;
GRANT SELECT, INSERT, DELETE ON表名 TO 用戶名1, 用戶名2;

-------------------------------------------------------------------
2.REVOKE 回收權限

REVOKE CONNECT, RESOURCE FROM 用戶名;
REVOKE SELECT ON 表名 FROM 用戶名;
REVOKE SELECT, INSERT, DELETE ON表名 FROM 用戶名1, 用戶名2;

 二.數據定義 (DDL) 部分
=======================================
1.CREATE (創建表, 索引, 視圖, 同義詞, 過程, 函數, 數據庫鏈接等)

ORACLE常用的字段類型有
CHAR            固定長度的字符串
VARCHAR2        可變長度的字符串
NUMBER(M,N)        數字型M是位數總長度, N是小數的長度
DATE            日期類型

創建表時要把較小的不為空的字段放在前面, 可能為空的字段放在后面

創建表時可以用中文的字段名, 但最好還是用英文的字段名

創建表時可以給字段加上默認值, 例如 DEFAULT SYSDATE
這樣每次插入和修改時, 不用程序操作這個字段都能得到動作的時間

創建表時可以給字段加上約束條件
例如 不允許重復 UNIQUE, 關鍵字 PRIMARY KEY

------------------------------------------------------------------        
2.ALTER    (改變表, 索引, 視圖等)

改變表的名稱
ALTER TABLE 表名1  TO 表名2;

在表的后面增加一個字段
ALTER TABLE表名 ADD 字段名 字段名描述;

修改表里字段的定義描述
ALTER TABLE表名 MODIFY字段名 字段名描述;

給表里的字段加上約束條件
ALTER TABLE 表名 ADD CONSTRAINT 約束名 PRIMARY KEY (字段名);
ALTER TABLE 表名 ADD CONSTRAINT 約束名 UNIQUE (字段名);

把表放在或取出數據庫的內存區
ALTER TABLE 表名 CACHE;
ALTER TABLE 表名 NOCACHE;

------------------------------------------------------------------
3.DROP    (刪除表, 索引, 視圖, 同義詞, 過程, 函數, 數據庫鏈接等)

刪除表和它所有的約束條件
DROP TABLE 表名 CASCADE CONSTRAINTS;

------------------------------------------------------------------
4.TRUNCATE (清空表里的所有記錄, 保留表的結構)
  TRUNCATE 表名;

 

 三.查詢語句 (SELECT) 部分
======================================

SELECT  字段名1, 字段名2, …… 
FROM    表名1, [表名2, ……] 
WHERE   條件; 
--------------------------
字段名可以帶入函數
  例如:  COUNT(*), MIN(字段名),  MAX(字段名),  AVG(字段名), DISTINCT(字段名), 
       TO_CHAR(DATE字段名,'YYYY-MM-DD HH24:MI:SS')
------------------------------
NVL(EXPR1, EXPR2)函數
解釋:    
IF EXPR1=NULL
                RETURN EXPR2
ELSE
               RETURN EXPR1
------------------------------
DECODE(AA﹐V1﹐R1﹐V2﹐R2.)函數
解釋: 
IF AA=V1 THEN RETURN R1
IF AA=V2 THEN RETURN R2
..…
ELSE
RETURN NULL
------------------------------
LPAD(char1,n,char2)函數
解釋:
字符char1按制定的位數n顯示,不足的位數用char2字符串替換左邊的空位
------------------------------
字段名之間可以進行算術運算
例如:  (字段名1*字段名1)/3


=====================================
查詢語句可以嵌套
---------------------
例如: 
SELECT …… FROM 
(
   SELECT …… 
   FROM表名1, [表名2, ……] 
   WHERE 條件1

WHERE 條件2;

======================================
兩個查詢語句的結果可以做集合操作
--------------------------------
例如: 並集  UNION    (去掉重復記錄), 
      並集  UNION ALL(不去掉重復記錄), 
      差集  MINUS,  
      交集  INTERSECT

====================================
分組查詢
------------
SELECT   字段名1, 字段名2, …… 
FROM     表名1, 表名2, ……
GROUP BY 字段名1 
HAVING 條件


===================================
兩個以上表之間的連接查詢
-----------------------
SELECT 字段名1, 字段名2, …… 
FROM   表名1, [表名2, ……] 
WHERE  表名1.字段名 = 表名2. 字段名 
[ AND ……] ;

SELECT 字段名1, 字段名2, …… 
FROM   表名1, [表名2, ……] 
WHERE  表名1.字段名 = 表名2. 字段名(+) 
[ AND ……] ;

有(+)號的字段位置自動補空值

===================================
查詢結果集的排序操作, 默認的排序是升序ASC, 降序是DESC
----------------------------------------------------
SELECT   字段名1, 字段名2, …… 
FROM     表名1, [表名2, ……] 
ORDER BY 字段名1, 字段名2 DESC;

===================================
字符串模糊比較的方法
----------------------
INSTR(字段名, ‘字符串’)>0    
字段名 LIKE  ‘字符串%’  [‘%字符串%’]
----------------------------------------------------------------
每個表都有一個隱含的字段ROWID, 它標記着記錄的唯一性. 

 

   四.ORACLE里常用的數據對象 (SCHEMA)
=====================================

1.索引 (INDEX)

CREATE INDEX 索引名ON 表名 ( 字段1, [字段2, ……] );
ALTER INDEX 索引名 REBUILD;

一個表的索引最好不要超過三個 (特殊的大表除外), 最好用單字段索引, 結合SQL語句的分析執行情況, 
也可以建立多字段的組合索引和基於函數的索引

ORACLE8.1.7字符串可以索引的最大長度為1578 單字節
ORACLE8.0.6字符串可以索引的最大長度為758 單字節

ORACLE DOC上說字符串最大可以建索引的長度約是:數據塊的大小(db_block_size)*40%
----------------------------------------------------------------

----------------------------------------------------------------
2.視圖 (VIEW)

CREATE VIEW 視圖名AS SELECT …. FROM …..;
ALTER VIEW視圖名 COMPILE;

視圖僅是一個SQL查詢語句, 它可以把表之間復雜的關系簡潔化.

----------------------------------------------------------------
3.同義詞 (SYNONMY)
CREATE SYNONYM同義詞名FOR 表名;
CREATE SYNONYM同義詞名FOR 表名@數據庫鏈接名;

----------------------------------------------------------------
4.數據庫鏈接 (DATABASE LINK)
CREATE DATABASE LINK數據庫鏈接名CONNECT TO 用戶名 IDENTIFIED BY 密碼 USING ‘數據庫連接字符串’;
    
數據庫連接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定義.

數據庫參數global_name=true時要求數據庫鏈接名稱跟遠端數據庫名稱一樣

數據庫全局名稱可以用以下命令查出
SELECT * FROM GLOBAL_NAME;

查詢遠端數據庫里的表
SELECT …… FROM 表名@數據庫鏈接名;

 

五.權限管理 (DCL) 語句
===========================================

1.GRANT    賦於權限
常用的系統權限集合有以下三個:
CONNECT(基本的連接), RESOURCE(程序開發), DBA(數據庫管理)
常用的數據對象權限有以下五個:
ALL     ON 數據對象名,     SELECT ON 數據對象名,     UPDATE ON 數據對象名,
DELETE     ON 數據對象名,  INSERT ON 數據對象名,   ALTER  ON 數據對象名

GRANT CONNECT, RESOURCE TO 用戶名;
GRANT SELECT ON 表名 TO 用戶名;
GRANT SELECT, INSERT, DELETE ON表名 TO 用戶名1, 用戶名2;

-------------------------------------------------------------------
2.REVOKE 回收權限

REVOKE CONNECT, RESOURCE FROM 用戶名;
REVOKE SELECT ON 表名 FROM 用戶名;
REVOKE SELECT, INSERT, DELETE ON表名 FROM 用戶名1, 用戶名2;

 

=======================================
        DDL 中使用子查詢
=======================================
create table 語句中的子查詢
--------------------------
create table dept1 (deptno, dname, loc) as
select deptno, dname, loc from dept;

create table emp1 as 
select * from emp;
=======================================
create view 中使用子查詢
-----------------------
create or replace view dept_20 as
select * from emp1 where deptno = 20 order by empno;


======================================
        DML 中使用子查詢
======================================
update 語句中使用子查詢
-----------------------
update emp1 set (sal,comm) =
( select sal, comm from emp1 where ename = 'WARD' )
where job = ( select job from emp1 where ename= 'WARD' )

======================================
delete 語句中使用子查詢
-----------------------
delete from emp1
where deptno = (select deptno from dept1 where dname = 'ACCOUNTING' )

=======================================
insert 語句中使用子查詢
-----------------------
insert into emp1
select * from emp
where deptno = (select deptno from where dname = 'ACCOUNTING')

=====================================

 

=====================================
             基礎查詢分類
=====================================
基本查詢 --- 所有列、指定列、where子句、order by子句
---------------------------------------------------
分組查詢 --- 組處理函數、group by子句、having子句
---------------------------------------------------
連接查詢 --- 相等連接、不等連接、自我連接
====================================

====================================
合並查詢 --- UNION,UNION ALL,INTERSECT,MINUS
-----------------------------------------------------
子查詢   --- 單行、多行、相關、標量、多列、DDL中、DML中
====================================


====================================

1。order by 子句必須放在最后。

2。組處理函數只能出現在選擇列表、order by子句、having子句中,
   不能出現在where子句和group by子句中。

3。在選擇列表中包含的列、表達式,則一定要出現在group by子句中。

4。where子句中可以使用單行子查詢,可以使用單行運算符。
   ( =,>,<,>=,<=,<> )

5。where子句中可以使用多行子查詢,可以使用多行運算符。
   ( in,not in,exists,not exists,all,any )

 

====================================
基本的Sql編寫注意事項
---------------------
1。盡量少用IN操作符,基本上所有的IN操作符都可以用EXISTS代替。 

2。不用NOT IN操作符,可以用NOT EXISTS或者外連接+替代。 

3。Oracle在執行IN子查詢時,首先執行子查詢,將查詢結果放入臨時表再執行主查詢。
   而EXIST則是首先檢查主查詢,然后運行子查詢直到找到第一個匹配項。
   NOT EXISTS 比 NOT IN 效率稍高。但具體在選擇IN或EXIST操作時,
   要根據主子表數據量大小來具體考慮。 

4。不用“<>”或者“!=”操作符。對不等於操作符的處理會造成全表掃描,
   可以用“<” or “>”代替。 

5。Where子句中出現IS NULL或者IS NOT NULL時,Oracle會停止使用索引而執行全表掃描。
   可以考慮在設計表時,對索引列設置為NOT NULL。這樣就可以用其他操作來取代判斷NULL的操作。 

6。當通配符“%”或者“_”作為查詢字符串的第一個字符時,索引不會被使用。 

7。對於有連接的列“||”,最后一個連接列索引會無效。盡量避免連接,
   可以分開連接或者使用不作用在列上的函數替代。 

8。如果索引不是基於函數的,那么當在Where子句中對索引列使用函數時,索引不再起作用。 

9。Where子句中避免在索引列上使用計算,否則將導致索引失效而進行全表掃描。 

10。對數據類型不同的列進行比較時,會使索引失效。 

11。用“>=”替代“>”。 

12。UNION操作符會對結果進行篩選,消除重復,數據量大的情況下可能會引起磁盤排序。
    如果不需要刪除重復記錄,應該使用UNION ALL。 

13。Oracle從下到上處理Where子句中多個查詢條件,所以表連接語句應寫在其他Where條件前,
    可以過濾掉最大數量記錄的條件必須寫在Where子句的末尾。 

14。Oracle從右到左處理From子句中的表名,所以在From子句中包含多個表的情況下,
    將記錄最少的表放在最后。

15。Order By語句中的非索引列會降低性能,可以通過添加索引的方式處理。
    嚴格控制在Order By語句中使用表達式。 

16。不同區域出現的相同的Sql語句,要保證查詢字符完全相同,以利用SGA共享池,
    防止相同的Sql語句被多次分析。 

17。當在Sql語句中連接多個表時,使用表的別名,並將之作為每列的前綴。這樣可以減少解析時間。

==================================
我們可以總結一下可能引起全表掃描的操作: 
------------------------------------------
1。在索引列上使用NOT或者“<>”; 

2。對索引列使用函數或者計算; 

3。NOT IN操作; 

4。通配符位於查詢字符串的第一個字符; 

5。IS NULL或者IS NOT NULL; 

6。多列索引,但它的第一個列並沒有被Where子句引用; 
========================================

轉自:http://www.blogjava.net/kiant/articles/234781.html#5


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM