一
數據更新語句 (DML) 部分
INSERT (往數據表裡插入記錄的語句)
INSERT INTO 表名(字段名
字段名
……) VALUES ( 值
值
……);
INSERT INTO 表名(字段名
字段名
……) SELECT (字段名
字段名
……) FROM 另外的表名;
字符串類型的字段值必須用單引號括起來
例如:
GOOD DAY
如果字段值裡包含單引號
需要進行字符串轉換
我們把它替換成兩個單引號
字符串類型的字段值超過定義的長度會出錯
最好在插入前進行長度校驗
日期字段的字段值可以用當前數據庫的系統時間SYSDATE
精確到秒或者用字符串轉換成日期型函數TO_DATE(
YYYY
MM
DD
) TO_DATE()還有很多種日期格式
可以參看ORACLE DOC
年
月
日 小時:分鐘:秒 的格式YYYY
MM
DD HH
:MI:SS
INSERT時最大可操作的字符串長度小於等於
個單字節
如果要插入更長的字符串
請考慮字段用CLOB類型
方法借用ORACLE裡自帶的DBMS_LOB程序包
INSERT時如果要用到從
開始自動增長的序列號
應該先建立一個序列號CREATE SEQUENCE 序列號的名稱 (最好是表名+序列號標記) INCREMENT BY
START WITH
MAXVALUE
CYCLE NOCACHE;
其中最大的值按字段的長度來定
如果定義的自動增長的序列號 NUMBER(
)
最大值為
INSERT 語句插入這個字段值為: 序列號的名稱
NEXTVAL
DELETE (刪除數據表裡記錄的語句)
DELETE FROM表名 WHERE 條件;
注意
刪除記錄並不能釋放ORACLE裡被占用的數據塊表空間
它只把那些被刪除的數據塊標成unused
如果確實要刪除一個大表裡的全部記錄
可以用 TRUNCATE 命令
它可以釋放占用的數據塊表空間
TRUNCATE TABLE 表名;
此操作不可回退
UPDATE (修改數據表裡記錄的語句)
UPDATE表名 SET 字段名
=值
字段名
=值
…… WHERE 條件;
如果修改的值N沒有賦值或定義時
將把原來的記錄內容清為NULL
最好在修改前進行非空校驗; 值N超過定義的長度會出錯
最好在插入前進行長度校驗
注意事項:
A
以上SQL語句對表都加上了行級鎖
確認完成後
必須加上事物處理結束的命令 COMMIT 才能正式生效
否則改變不一定寫入數據庫裡
如果想撤回這些操作
可以用命令 ROLLBACK 復原
B
在運行INSERT
DELETE 和 UPDATE 語句前最好估算一下可能操作的記錄范圍
應該把它限定在較小 (一萬條記錄) 范圍內
否則ORACLE處理這個事物用到很大的回退段
程序響應慢甚至失去響應
如果記錄數上十萬以上這些操作
可以把這些SQL語句分段分次完成
其間加上COMMIT 確認事物處理
二
數據定義 (DDL) 部分
CREATE (創建表
索引
視圖
同義詞
過程
函數
數據庫鏈接等)
ORACLE常用的字段類型有
CHAR 固定長度的字符串
VARCHAR
可變長度的字符串
NUMBER(M
N) 數字型M是位數總長度
N是小數的長度
DATE 日期類型
創建表時要把較小的不為空的字段放在前面
可能為空的字段放在後面創建表時可以用中文的字段名
但最好還是用英文的字段名
創建表時可以給字段加上默認值
例如 DEFAULT SYSDATE這樣每次插入和修改時
不用程序操作這個字段都能得到動作的時間
創建表時可以給字段加上約束條件
例如 不允許重復 UNIQUE
關鍵字 PRIMARY KEY
ALTER (改變表
索引
視圖等)
改變表的名稱
ALTER TABLE 表名
TO 表名
;
在表的後面增加一個字段
ALTER TABLE表名 ADD 字段名 字段名描述;
修改表裡字段的定義描述
ALTER TABLE表名 MODIFY字段名 字段名描述;
給表裡的字段加上約束條件
ALTER TABLE 表名 ADD CONSTRAINT 約束名 PRIMARY KEY (字段名);
ALTER TABLE 表名 ADD CONSTRAINT 約束名 UNIQUE (字段名);
把表放在或取出數據庫的內存區
ALTER TABLE 表名 CACHE;
ALTER TABLE 表名 NOCACHE;
DROP (刪除表
索引
視圖
同義詞
過程
函數
數據庫鏈接等)
刪除表和它所有的約束條件
DROP TABLE 表名 CASCADE CONSTRAINTS;
TRUNCATE (清空表裡的所有記錄
保留表的結構)
TRUNCATE 表名;
三
查詢語句 (SELECT) 部分
SELECT字段名
字段名
…… FROM 表名
[表名
……] WHERE 條件;
字段名可以帶入函數
例如: COUNT(*)
MIN(字段名)
MAX(字段名)
AVG(字段名)
DISTINCT(字段名)
TO_CHAR(DATE字段名
YYYY
MM
DD HH
:MI:SS
)
NVL(EXPR
EXPR
)函數
解釋:
IF EXPR
=NULL
RETURN EXPR
ELSE
RETURN EXPR
DECODE(AA﹐V
﹐R
﹐V
﹐R
)函數
解釋:
IF AA=V
THEN RETURN R
IF AA=V
THEN RETURN R
…
ELSE
RETURN NULL
LPAD(char
n
char
)函數
解釋:
字符char
按制定的位數n顯示
不足的位數用char
字符串替換左邊的空位
字段名之間可以進行算術運算
例如: (字段名
*字段名
)/
查詢語句可以嵌套
例如: SELECT …… FROM
(SELECT …… FROM表名
[表名
……] WHERE 條件) WHERE 條件
;
兩個查詢語句的結果可以做集合操作
例如: 並集UNION(去掉重復記錄)
並集UNION ALL(不去掉重復記錄)
差集MINUS
交集INTERSECT
分組查詢
SELECT字段名
字段名
…… FROM 表名
[表名
……] GROUP BY字段名
[HAVING 條件] ;
兩個以上表之間的連接查詢
SELECT字段名
字段名
…… FROM 表名
[表名
……] WHERE
表名
字段名 = 表名
字段名 [ AND ……] ;
SELECT字段名
字段名
…… FROM 表名
[表名
……] WHERE
表名
字段名 = 表名
字段名(+) [ AND ……] ;
有(+)號的字段位置自動補空值
查詢結果集的排序操作
默認的排序是升序ASC
降序是DESC
SELECT字段名
字段名
…… FROM 表名
[表名
……]
ORDER BY字段名
字段名
DESC;
字符串模糊比較的方法
INSTR(字段名
字符串
)>
字段名 LIKE
字符串%
[
%字符串%
]
每個表都有一個隱含的字段ROWID
它標記著記錄的唯一性
四
ORACLE裡常用的數據對象 (SCHEMA)
索引 (INDEX)
CREATE INDEX 索引名ON 表名 ( 字段
[字段
……] );
ALTER INDEX 索引名 REBUILD;
一個表的索引最好不要超過三個 (特殊的大表除外)
最好用單字段索引
結合SQL語句的分析執行情況
也可以建立多字段的組合索引和基於函數的索引
ORACLE
字符串可以索引的最大長度為
單字節
ORACLE
字符串可以索引的最大長度為
單字節
視圖 (VIEW)
CREATE VIEW 視圖名AS SELECT …
FROM …
;
ALTER VIEW視圖名 COMPILE;
視圖僅是一個SQL查詢語句
它可以把表之間復雜的關系簡潔化
同義詞 (SYNONMY)
CREATE SYNONYM同義詞名FOR 表名;
CREATE SYNONYM同義詞名FOR 表名@數據庫鏈接名;
數據庫鏈接 (DATABASE LINK)
CREATE DATABASE LINK數據庫鏈接名CONNECT TO 用戶名 IDENTIFIED BY 密碼 USING
數據庫連接字符串
; 數據庫連接字符串可以用NET
EASY CONFIG或者直接修改TNSNAMES
ORA裡定義
數據庫參數global_name=true時要求數據庫鏈接名稱跟遠端數據庫名稱一樣
數據庫全局名稱可以用以下命令查出
SELECT * FROM GLOBAL_NAME;
查詢遠端數據庫裡的表
SELECT …… FROM 表名@數據庫鏈接名;
五
權限管理 (DCL) 語句
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 用戶名
用戶名
;
REVOKE 回收權限
REVOKE CONNECT
RESOURCE FROM 用戶名;
REVOKE SELECT ON 表名 FROM 用戶名;
REVOKE SELECT
INSERT
DELETE ON表名 FROM 用戶名
用戶名
;
ORACLE 常用的SQL語法和數據對象
From:http://tw.wingwit.com/Article/program/Oracle/201311/18318.html