免费高清特黄a大片,九一h片在线免费看,a免费国产一级特黄aa大,国产精品国产主播在线观看,成人精品一区久久久久,一级特黄aa大片,俄罗斯无遮挡一级毛片

分享

超詳細(xì)的SQL語(yǔ)句語(yǔ)法(一)——常用的SQL語(yǔ)句語(yǔ)法

 iop_007 2010-08-15
超詳細(xì)的SQL語(yǔ)句語(yǔ)法(一)——常用的SQL語(yǔ)句語(yǔ)法
2008年03月05日 星期三 01:40

比較常用的SQL語(yǔ)句語(yǔ)法(Oracle)

一.數(shù)據(jù)控制語(yǔ)句 (DML) 部分

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開(kāi)始自動(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 才能正式生效,
            否則改變不一定寫(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常用的字段類型有
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é)

orACLE DOC上說(shuō)字符串最大可以建索引的長(zhǎng)度約是:數(shù)據(jù)塊的大小(db_block_size)*40%

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(程序開(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 用戶名;
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;
以下是MS SQL

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多