校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > ORACLE 常用的SQL語(yǔ)法和數(shù)據(jù)對(duì)象

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

熱門(mén)標(biāo)簽:南通防封外呼系統(tǒng)運(yùn)營(yíng)商 淮安自動(dòng)外呼系統(tǒng)開(kāi)發(fā) 修改高德地圖標(biāo)注 地圖標(biāo)注原件 廣州市400電話(huà)辦理 語(yǔ)音電話(huà)機(jī)器人缺點(diǎn) 百變地圖標(biāo)注 宜賓外呼系統(tǒng)廠家 語(yǔ)音電話(huà)機(jī)器人營(yíng)銷(xiāo)方案

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

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

  字符串類(lèi)型的字段值必須用單引號(hào)括起來(lái), 例如: 'GOOD DAY'
  如果字段值里包含單引號(hào)' 需要進(jìn)行字符串轉(zhuǎn)換, 我們把它替換成兩個(gè)單引號(hào)''. 字符串類(lèi)型的字段值超過(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類(lèi)型,方法借用ORACLE里自帶的DBMS_LOB程序包.

  INSERT時(shí)如果要用到從1開(kāi)始自動(dòng)增長(zhǎng)的序列號(hào), 應(yīng)該先建立一個(gè)序列號(hào)CREATE SEQUENCE 序列號(hào)的名稱(chēng) (最好是表名+序列號(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)的名稱(chēng).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 才能正式生效, 否則改變不一定寫(xiě)入數(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常用的字段類(lèi)型有
  CHAR 固定長(zhǎng)度的字符串
  VARCHAR2 可變長(zhǎng)度的字符串
  NUMBER(M,N) 數(shù)字型M是位數(shù)總長(zhǎng)度, N是小數(shù)的長(zhǎng)度
  DATE 日期類(lèi)型

  創(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 (改變表, 索引, 視圖等)

  改變表的名稱(chēng)
  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 表名;三.查詢(xún)語(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

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

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

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

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

  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ǔ)空值

  查詢(xún)結(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查詢(xún)語(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 用戶(hù)名 IDENTIFIED BY 密碼 USING ‘?dāng)?shù)據(jù)庫(kù)連接字符串'; 數(shù)據(jù)庫(kù)連接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定義.

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

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

  查詢(xún)遠(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(程序開(kāi)發(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 用戶(hù)名;
  GRANT SELECT ON 表名 TO 用戶(hù)名;
  GRANT SELECT, INSERT, DELETE ON表名 TO 用戶(hù)名1, 用戶(hù)名2;

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

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

您可能感興趣的文章:
  • ORACLE 查詢(xún)被鎖住的對(duì)象,并結(jié)束其會(huì)話(huà)的方法
  • 解析Oracle數(shù)據(jù)庫(kù)中的對(duì)象集合schema
  • oracle查看會(huì)話(huà)鎖定的所有對(duì)象代碼分享
  • Oracle使用PL/SQL操作COM對(duì)象
  • 基于Oracle的面向?qū)ο蠹夹g(shù)入門(mén)基礎(chǔ)簡(jiǎn)析開(kāi)發(fā)者網(wǎng)絡(luò)Oracle
  • PHP 5 數(shù)據(jù)對(duì)象 (PDO) 抽象層與 Oracle
  • MS-sql 2005拒絕了對(duì)對(duì)象 ''xxx'' (數(shù)據(jù)庫(kù) ''xxx'',架構(gòu) ''dbo'')的 SELECT 權(quán)限的解決方法
  • 重新編譯PLSQL中的無(wú)效對(duì)象或者指定的對(duì)象 的方法
  • asp sqlserver 執(zhí)行存儲(chǔ)過(guò)程返回記錄集報(bào)對(duì)象關(guān)閉時(shí)不允許操作
  • 利用函數(shù)返回oracle對(duì)象表的三種方法

標(biāo)簽:嘉峪關(guān) 股票投資 聊城 池州 南平 通化 南平 襄陽(yáng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ORACLE 常用的SQL語(yǔ)法和數(shù)據(jù)對(duì)象》,本文關(guān)鍵詞  ORACLE,常用的,常,用的,SQL,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ORACLE 常用的SQL語(yǔ)法和數(shù)據(jù)對(duì)象》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于ORACLE 常用的SQL語(yǔ)法和數(shù)據(jù)對(duì)象的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 汽车| 都昌县| 安康市| 余江县| 贵德县| 新安县| 繁昌县| 新邵县| 营山县| 绥芬河市| 平武县| 南昌县| 阳朔县| 田阳县| 年辖:市辖区| 龙海市| 时尚| 闽清县| 绿春县| 闵行区| 鄱阳县| 桓台县| 眉山市| 兴山县| 江达县| 延边| 静海县| 察哈| 长葛市| 岳阳市| 新野县| 黄冈市| 黄石市| 兴安盟| 运城市| 平顺县| 武汉市| 鄯善县| 天等县| 利川市| 师宗县|