ORACLE常用的SQL語法和資料物件(轉)
ORACLE常用的SQL語法和資料物件(轉)[@more@]一.資料控制語句 (DML) 部分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:SSINSERT時最大可操作的字串長度小於等於4000個單位元組, 如果要插入更長的字串, 請考慮欄位用CLOB型別,方法借用ORACLE裡自帶的DBMS_LOB程式包.INSERT時如果要用到從1開始自動增長的序列號, 應該先建立一個序列號CREATE SEQUENCE 序列號的名稱 (最好是表名+序列號標記) INCREMENT BY 1 START WITH 1 MAXVALUE 99999 CYCLE NOCACHE;其中最大的值按欄位的長度來定, 如果定義的自動增長的序列號 NUMBER(6) , 最大值為999999INSERT 語句插入這個欄位值為: 序列號的名稱.NEXTVAL2.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 KEY2.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=NULLRETURN EXPR2ELSERETURN EXPR1DECODE(AA﹐V1﹐R1﹐V2﹐R2....)函式解釋: IF AA=V1 THEN RETURN R1IF AA=V2 THEN RETURN R2..…ELSERETURN NULLLPAD(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, 降序是DESCSELECT欄位名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
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8225414/viewspace-945302/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- ORACLE常用的SQL語法和資料物件OracleSQL物件
- ORACLE 常用的SQL語法和資料物件OracleSQL物件
- Oracle常用sql語法集合OracleSQL
- 常用的 SQL 語法SQL
- 1.4 資料庫和常用SQL語句(正文)——MySQL資料庫命令和SQL語句資料庫MySql
- SQLServer資料庫管理常用的SQL和T-SQL語句SQLServer資料庫
- Oracle資料庫維護常用SQL語句集合Oracle資料庫SQL
- 資料庫常用的sql語句大全--sql資料庫SQL
- SQL Server資料庫管理常用SQL和T-SQL語句SQLServer資料庫
- (轉)Oracle常用資料字典查詢語句Oracle
- 轉貼:Oracle維護常用SQL語句OracleSQL
- Oracle SQL Loader的詳細語法 <轉>OracleSQL
- 資料庫-SQL 語法資料庫SQL
- 資料庫常用sql 語句資料庫SQL
- oracle常用SQL語句OracleSQL
- 《轉》SqlServer和Oracle中一些常用的sql語句3-行列轉換SQLServerOracle
- Sql Server 資料庫學習-常用資料庫 物件SQLServer資料庫物件
- 資料庫常用操作SQL語句資料庫SQL
- 資料庫常用的sql語句彙總資料庫SQL
- 資料庫巡檢常用的SQL語句資料庫SQL
- SQLServer資料庫管理的常用SQL語句SQLServer資料庫
- Oracle和SQL對比語法總結OracleSQL
- oracle資料庫常用語句Oracle資料庫
- hive sql 常用語法詳解HiveSQL
- Oracle資料庫DBA日常Sql列表及常用檢視(轉)Oracle資料庫SQL
- Oracle資料庫資料物件分析(轉)Oracle資料庫物件
- Linux資料庫:SQL語法參考手冊(轉)Linux資料庫SQL
- 工作中常用的oracle資料庫sqlOracle資料庫SQL
- 資料庫-SQL基礎語法資料庫SQL
- MongoRepository查詢資料常用語法Go
- ORACLE的基本語法(轉)Oracle
- 3分鐘看完SQL常用語法SQL
- 15 個常用的 SQL Server 高階語法SQLServer
- sql case語法和plsql case語法!SQL
- [SQL] Oracle基礎語法SQLOracle
- Oracle SQL的一些語法OracleSQL
- Oracle維護常用SQL語句OracleSQL
- Oracle sql with 語句語法與例子OracleSQL