一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫(kù)技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫(kù) - Oracle - ORACLE 常用的SQL語(yǔ)法和數(shù)據(jù)對(duì)象

ORACLE 常用的SQL語(yǔ)法和數(shù)據(jù)對(duì)象

2019-10-27 16:32ORACLE教程網(wǎng) Oracle

ORACLE 常用的SQL語(yǔ)法和數(shù)據(jù)對(duì)象

1.INSERT (往數(shù)據(jù)表里插入記錄的語(yǔ)句)

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

  字符串類型的字段值必須用單引號(hào)括起來(lái), 例如: 'GOOD DAY'
  如果字段值里包含單引號(hào)' 需要進(jìn)行字符串轉(zhuǎn)換, 我們把它替換成兩個(gè)單引號(hào)''. 字符串類型的字段值超過(guò)定義的長(zhǎng)度會(huì)出錯(cuò), 最好在插入前進(jìn)行長(zhǎng)度校驗(yàn).

  日期字段的字段值可以用當(dāng)前數(shù)據(jù)庫(kù)的系統(tǒng)時(shí)間SYSDATE, 精確到秒或者用字符串轉(zhuǎn)換成日期型函數(shù)TO_DATE(‘2001-08-01','YYYY-MM-DD') TO_DATE()還有很多種日期格式, 可以參看ORACLE DOC. 年-月-日 小時(shí):分鐘:秒 的格式Y(jié)YYY-MM-DD HH24:MI:SS

  INSERT時(shí)最大可操作的字符串長(zhǎng)度小于等于4000個(gè)單字節(jié), 如果要插入更長(zhǎng)的字符串, 請(qǐng)考慮字段用CLOB類型,方法借用ORACLE里自帶的DBMS_LOB程序包.

  INSERT時(shí)如果要用到從1開始自動(dòng)增長(zhǎng)的序列號(hào), 應(yīng)該先建立一個(gè)序列號(hào)CREATE SEQUENCE 序列號(hào)的名稱 (最好是表名+序列號(hào)標(biāo)記) INCREMENT BY 1 START WITH 1 
  MAXVALUE 99999 CYCLE NOCACHE;
  其中最大的值按字段的長(zhǎng)度來(lái)定, 如果定義的自動(dòng)增長(zhǎng)的序列號(hào) NUMBER(6) , 最大值為999999
  INSERT 語(yǔ)句插入這個(gè)字段值為: 序列號(hào)的名稱.NEXTVAL

2.DELETE (刪除數(shù)據(jù)表里記錄的語(yǔ)句)

  DELETE FROM表名 WHERE 條件;

  注意:刪除記錄并不能釋放ORACLE里被占用的數(shù)據(jù)塊表空間. 它只把那些被刪除的數(shù)據(jù)塊標(biāo)成unused.

  如果確實(shí)要?jiǎng)h除一個(gè)大表里的全部記錄, 可以用 TRUNCATE 命令, 它可以釋放占用的數(shù)據(jù)塊表空間
  TRUNCATE TABLE 表名; 
  此操作不可回退.

3.UPDATE (修改數(shù)據(jù)表里記錄的語(yǔ)句)

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

  如果修改的值N沒(méi)有賦值或定義時(shí), 將把原來(lái)的記錄內(nèi)容清為NULL, 最好在修改前進(jìn)行非空校驗(yàn); 值N超過(guò)定義的長(zhǎng)度會(huì)出錯(cuò), 最好在插入前進(jìn)行長(zhǎng)度校驗(yàn)..

  注意事項(xiàng): 
  A. 以上SQL語(yǔ)句對(duì)表都加上了行級(jí)鎖,確認(rèn)完成后, 必須加上事物處理結(jié)束的命令 COMMIT 才能正式生效, 否則改變不一定寫入數(shù)據(jù)庫(kù)里. 如果想撤回這些操作, 可以用命令 ROLLBACK 復(fù)原.

  B. 在運(yùn)行INSERT, DELETE 和 UPDATE 語(yǔ)句前最好估算一下可能操作的記錄范圍, 應(yīng)該把它限定在較小 (一萬(wàn)條記錄) 范圍內(nèi),. 否則ORACLE處理這個(gè)事物用到很大的回退段. 程序響應(yīng)慢甚至失去響應(yīng). 如果記錄數(shù)上十萬(wàn)以上這些操作, 可以把這些SQL語(yǔ)句分段分次完成, 
  其間加上COMMIT 確認(rèn)事物處理.二.數(shù)據(jù)定義 (DDL) 部分

1.CREATE (創(chuàng)建表, 索引, 視圖, 同義詞, 過(guò)程, 函數(shù), 數(shù)據(jù)庫(kù)鏈接等)

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

  創(chuàng)建表時(shí)要把較小的不為空的字段放在前面, 可能為空的字段放在后面創(chuàng)建表時(shí)可以用中文的字段名, 但最好還是用英文的字段名

  創(chuàng)建表時(shí)可以給字段加上默認(rèn)值, 例如 DEFAULT SYSDATE這樣每次插入和修改時(shí), 不用程序操作這個(gè)字段都能得到動(dòng)作的時(shí)間

  創(chuàng)建表時(shí)可以給字段加上約束條件
  例如 不允許重復(fù) UNIQUE, 關(guān)鍵字 PRIMARY KEY

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

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

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

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

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

  把表放在或取出數(shù)據(jù)庫(kù)的內(nèi)存區(qū)
  ALTER TABLE 表名 CACHE;
  ALTER TABLE 表名 NOCACHE;

3.DROP (刪除表, 索引, 視圖, 同義詞, 過(guò)程, 函數(shù), 數(shù)據(jù)庫(kù)鏈接等)

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

4.TRUNCATE (清空表里的所有記錄, 保留表的結(jié)構(gòu))

  TRUNCATE 表名;三.查詢語(yǔ)句 (SELECT) 部分

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

  字段名可以帶入函數(shù)
  例如: COUNT(*), MIN(字段名), MAX(字段名), AVG(字段名), DISTINCT(字段名), TO_CHAR(DATE字段名,'YYYY-MM-DD HH24:MI:SS')

  NVL(EXPR1, EXPR2)函數(shù)
  解釋: 
  IF EXPR1=NULL
  RETURN EXPR2
  ELSE
  RETURN EXPR1

  DECODE(AA﹐V1﹐R1﹐V2﹐R2....)函數(shù)
  解釋: 
  IF AA=V1 THEN RETURN R1
  IF AA=V2 THEN RETURN R2
  ..…
  ELSE
  RETURN NULL

  LPAD(char1,n,char2)函數(shù)
  解釋:
  字符char1按制定的位數(shù)n顯示,不足的位數(shù)用char2字符串替換左邊的空位

  字段名之間可以進(jìn)行算術(shù)運(yùn)算
  例如: (字段名1*字段名1)/3

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

  兩個(gè)查詢語(yǔ)句的結(jié)果可以做集合操作
  例如: 并集UNION(去掉重復(fù)記錄), 并集UNION ALL(不去掉重復(fù)記錄), 差集MINUS, 交集INTERSECT

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

  兩個(gè)以上表之間的連接查詢

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

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

  有(+)號(hào)的字段位置自動(dòng)補(bǔ)空值

  查詢結(jié)果集的排序操作, 默認(rèn)的排序是升序ASC, 降序是DESC

  SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] 
  ORDER BY字段名1, 字段名2 DESC;

  字符串模糊比較的方法

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

  每個(gè)表都有一個(gè)隱含的字段ROWID, 它標(biāo)記著記錄的唯一性.

ORACLE里常用的數(shù)據(jù)對(duì)象 (SCHEMA)

  1.索引 (INDEX)

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

  一個(gè)表的索引最好不要超過(guò)三個(gè) (特殊的大表除外), 最好用單字段索引, 結(jié)合SQL語(yǔ)句的分析執(zhí)行情況, 也可以建立多字段的組合索引和基于函數(shù)的索引

  ORACLE8.1.7字符串可以索引的最大長(zhǎng)度為1578 單字節(jié)
  ORACLE8.0.6字符串可以索引的最大長(zhǎng)度為758 單字節(jié)

  2.視圖 (VIEW)

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

  視圖僅是一個(gè)SQL查詢語(yǔ)句, 它可以把表之間復(fù)雜的關(guān)系簡(jiǎn)潔化.

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

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

  數(shù)據(jù)庫(kù)參數(shù)global_name=true時(shí)要求數(shù)據(jù)庫(kù)鏈接名稱跟遠(yuǎn)端數(shù)據(jù)庫(kù)名稱一樣

  數(shù)據(jù)庫(kù)全局名稱可以用以下命令查出
  SELECT * FROM GLOBAL_NAME;

  查詢遠(yuǎn)端數(shù)據(jù)庫(kù)里的表
  SELECT …… FROM 表名@數(shù)據(jù)庫(kù)鏈接名;

權(quán)限管理 (DCL) 語(yǔ)句

  1.GRANT 賦于權(quán)限
  常用的系統(tǒng)權(quán)限集合有以下三個(gè):
  CONNECT(基本的連接), RESOURCE(程序開發(fā)), DBA(數(shù)據(jù)庫(kù)管理)
  常用的數(shù)據(jù)對(duì)象權(quán)限有以下五個(gè):
  ALL ON 數(shù)據(jù)對(duì)象名, SELECT ON 數(shù)據(jù)對(duì)象名, UPDATE ON 數(shù)據(jù)對(duì)象名DELETE ON 數(shù)據(jù)對(duì)象名, INSERT ON 數(shù)據(jù)對(duì)象名, ALTER ON 數(shù)據(jù)對(duì)象名

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

  2.REVOKE 回收權(quán)限

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: free性丰满hd性欧美人体 | 久久国产精品无码视欧美 | 久久综合视频网站 | 草莓视频在线观看免费 | 国产99视频精品免费视频免里 | 456在线观看| 成人先锋 | 国产精品最新资源网 | 疯狂伦交1一6小说 | 星空无限传媒xk8129 | 国产福利微拍精品一区二区 | 色婷婷综合缴情综六月 | 久久综合久综合久久鬼色 | 91热爆| 国产精品一区二区三区免费 | 妇女澡堂淋浴性 | 午夜福利理论片高清在线 | 办公室大战秘书呻吟 | 欧美高清日韩 | 波多野结中文字幕在线69视频 | 久久这里只有精品国产精品99 | 视频大全在线观看免费 | 男人机机桶女人机机 | 蜜月aⅴ免费一区二区三区 蜜桃影像传媒推广 | 国产精品久久久久不卡绿巨人 | 免费高清在线 | 恩爱夫妇交换小说 | 欧美日韩高清一区 | 国产一区日韩二区欧美三区 | 桃色视频软件 | piss美女厕所小便 | 欧美伊香蕉久久综合类网站 | 国产无限免费观看黄网站 | 亚洲国产区男人本色在线观看欧美 | 日韩去日本高清在线 | 免费观看欧美一级高清 | 69pao强力打造免费高速 | 海派甜心完整版在线观看 | 暖暖中国免费观看高清完整版 | 和日本免费不卡在线v | 国语第一次处破女 |