| SQL數據庫完全手冊 日期:2001-3-24 0:47:00 出處:電腦報 作者:未知 | |
| ##1 二、SQL數據庫數據體系結構 SQL數據庫的數據體系結構基本上是三級結構,但使用術(shù)語(yǔ)與傳統關(guān)系模型術(shù)語(yǔ)不同。在SQL中,關(guān)系模式(模式)稱(chēng)為“基本表”(base table);存儲模式(內模式)稱(chēng)為“存儲文件”(stored file);子模式(外模式)稱(chēng)為“視圖”(view);元組稱(chēng)為“行”(row);屬性稱(chēng)為“列”(column)。名稱(chēng)對稱(chēng)如^00100009a^: ##1 三、SQL語(yǔ)言的組成 在正式學(xué)習SQL語(yǔ)言之前,首先讓我們對SQL語(yǔ)言有一個(gè)基本認識,介紹一下SQL語(yǔ)言的組成: 1.一個(gè)SQL數據庫是表(Table)的集合,它由一個(gè)或多個(gè)SQL模式定義。 2.一個(gè)SQL表由行集構成,一行是列的序列(集合),每列與行對應一個(gè)數據項。 3.一個(gè)表或者是一個(gè)基本表或者是一個(gè)視圖?;颈硎菍?shí)際存儲在數據庫的表,而視圖是由若干基本表或其他視圖構成的表的定義。 4.一個(gè)基本表可以跨一個(gè)或多個(gè)存儲文件,一個(gè)存儲文件也可存放一個(gè)或多個(gè)基本表。每個(gè)存儲文件與外部存儲上一個(gè)物理文件對應。 5.用戶(hù)可以用SQL語(yǔ)句對視圖和基本表進(jìn)行查詢(xún)等操作。在用戶(hù)角度來(lái)看,視圖和基本表是一樣的,沒(méi)有區別,都是關(guān)系(表格)。 6.SQL用戶(hù)可以是應用程序,也可以是終端用戶(hù)。SQL語(yǔ)句可嵌入在宿主語(yǔ)言的程序中使用,宿主語(yǔ)言有FORTRAN,COBOL,PASCAL,PL/I,C和Ada語(yǔ)言等。SQL用戶(hù)也能作為獨立的用戶(hù)接口,供交互環(huán)境下的終端用戶(hù)使用。 ##1 四、對數據庫進(jìn)行操作 SQL包括了所有對數據庫的操作,主要是由4個(gè)部分組成: 1.數據定義:這一部分又稱(chēng)為“SQL DDL”,定義數據庫的邏輯結構,包括定義數據庫、基本表、視圖和索引4部分。 2.數據操縱:這一部分又稱(chēng)為“SQL DML”,其中包括數據查詢(xún)和數據更新兩大類(lèi)操作,其中數據更新又包括插入、刪除和更新三種操作。 3.數據控制:對用戶(hù)訪(fǎng)問(wèn)數據的控制有基本表和視圖的授權、完整性規則的描述,事務(wù)控制語(yǔ)句等。 4.嵌入式SQL語(yǔ)言的使用規定:規定SQL語(yǔ)句在宿主語(yǔ)言的程序中使用的規則。 下面我們將分別介紹: ##2 (一)數據定義 SQL數據定義功能包括定義數據庫、基本表、索引和視圖。 首先,讓我們了解一下SQL所提供的基本數據類(lèi)型:(如^00100009b^) 1.數據庫的建立與刪除 (1)建立數據庫:數據庫是一個(gè)包括了多個(gè)基本表的數據集,其語(yǔ)句格式為: CREATE DATABASE <數據庫名> [其它參數] 其中,<數據庫名>在系統中必須是唯一的,不能重復,不然將導致數據存取失誤。[其它參數]因具體數據庫實(shí)現系統不同而異。 例:要建立項目管理數據庫(xmmanage),其語(yǔ)句應為: CREATE DATABASE xmmanage (2) 數據庫的刪除:將數據庫及其全部?jì)热輳南到y中刪除。 其語(yǔ)句格式為:DROP DATABASE <數據庫名> 例:刪除項目管理數據庫(xmmanage),其語(yǔ)句應為: DROP DATABASE xmmanage 2.基本表的定義及變更 本身獨立存在的表稱(chēng)為基本表,在SQL語(yǔ)言中一個(gè)關(guān)系唯一對應一個(gè)基本表?;颈淼亩x指建立基本關(guān)系模式,而變更則是指對數據庫中已存在的基本表進(jìn)行刪除與修改。 (1)基本表的定義:基本表是非導出關(guān)系,其定義涉及表名、列名及數據類(lèi)型等,其語(yǔ)句格式為: CREATE TABLE[<數據庫名>.]<表名> (<列名> 數據類(lèi)型 [缺省值] [NOT NULL / NULL] [,<列名> 數據類(lèi)型 [缺省值] [NOT NULL / NULL]]...... [,UNIQUE (列名[,列名]......)] [,PRIMARY KEY(列名)] [,FOREIGN KEY(列名[,列名]......)REFERENCE <表名>(列名[,列名]......)] [,CHECK(條件)] [其它參數]) 其中,〈數據庫名〉.]指出將新建立的表存放于該數據庫中; 新建的表由兩部分組成:其一為表和一組列名,其二是實(shí)際存放的數據(即可在定義表的同時(shí),直接存放數據到表中); 列名為用戶(hù)自定義的易于理解的名稱(chēng),列名中不能使用空格; 數據類(lèi)型為上面所介紹的幾種標準數據類(lèi)型; [NOT NULL/NULL]指出該列是否允許存放空值,SQL語(yǔ)言支持空值的概念,所謂空值是“不知道”或“無(wú)意義”的值,值得注意的是數據“0”和空格都不是空值,系統一般默認允許為空值,所以當不允許為空值時(shí),必須明確使用NOT NULL; [,UNIQUE]將列按照其規定的順序進(jìn)行排列,如不指定排列順序,則按列的定義順序排列; [PRIMARY KEY]用于指定表的主鍵(即關(guān)系中的主屬性),實(shí)體完整性約束條件規定:主鍵必須是唯一的,非空的; [,FOREIGN KEY (列名[,列名]......) REFERENCE<表名>(列名[,列名]......)]是用于指定外鍵參照完整性約束條件,FOREIGN KEY指定相關(guān)列為外鍵,其參照對象為另外一個(gè)表的指定列,即使用REFERENCE引入的外表中的列,當不指定外表列名時(shí),系統將默認其列名與參照鍵的列名相同,要注意的是:使用外鍵時(shí)必須使用參照,另外數據的外鍵參照完整性約束條件規定:外鍵的值要么與相對應的主鍵相同,要么為空值(具體由實(shí)現系統不同而異) [,CHECK]用于使用指定條件對存入表中的數據進(jìn)行檢查,以確定其合法性,提高數據的安全性。 例:要建立一個(gè)學(xué)生情況表(student) CREATE TABLE student //創(chuàng )建基本表student (st_class CHAR(8),// 定義列st_class班級,數據類(lèi)型為8位定長(cháng)字符串 st_no CHAR(10) NOT NULL,//定義列st_no學(xué)號,類(lèi)型為10位定長(cháng)字符串,非空 st_name CHAR(8) NOT NULL,//定義列st_name姓名,類(lèi)型為8位定長(cháng)字符串,非空 st_sex CHAR(2),//定義列st_sex性別,類(lèi)型為2位定長(cháng)字符串 st_age SMALLINT,//定義列st_age年齡,類(lèi)型為短整型 PRIMARY KEY (st_no))//定義st_no學(xué)號為主鍵。 例:要建立課程設置表(subject) CREATE TABLE subject//創(chuàng )建基本表subject (su_no CHAR(4) NOT NULL,// 定義列su_no課號,類(lèi)型為4位定長(cháng)字符串,非空 su_subject CHAR(20) NOT NULL,// 定義列su_subject課程名,類(lèi)型為20位定長(cháng)字符串,非空 su_credit INTEGER,// 定義列su_credit學(xué)分,類(lèi)型為長(cháng)整數 su_period INTEGER,//定義列su_period學(xué)時(shí),類(lèi)型為長(cháng)整數 su_preno CHAR(4),//定義列su_preno先修課號,類(lèi)型為4位定長(cháng)字符串 PRIMARY KEY(su_no))//定義su_no課號為主鍵。 例:要建立學(xué)生選課表(score) CREATE TABLE score //創(chuàng )建基本表score (st_no CHAR(10),//定義列st_no學(xué)號,類(lèi)型為10位定長(cháng)字符串 su_no CHAR(4),//定義列su_no課號,類(lèi)型為4位定長(cháng)字符串 sc_score INTEGER NULL,//定義列sc_score,類(lèi)型為長(cháng)整形,可以為空值 FOREIGN KEY (st_no) REFERENCE student,//從表student中引入參照外鍵st_no,以確保本表與表student的關(guān)聯(lián)與同步 FOREIGN KEY (suno) REFERENCE subject)//從表subject中引入參照外鍵su_no,以確保本表與表subject的關(guān)聯(lián)與同步 (2)基本表的刪除:用以從數據庫中刪除一個(gè)基本表及其全部?jì)热?,其語(yǔ)句格式為: DROP TABLE[<數據庫名>.]表名 例如:將上面建立的表都刪除 DROP TABLE student,subject,score (3)基本表的修改:在基本表建立并使用一段時(shí)間后,可能需要根據實(shí)際要求對基本表的結構進(jìn)行修改,即增加新的屬性或刪除屬性。 增加屬性的語(yǔ)句格式為: ALTER TABLE [<數據庫名>.]表名 ADD (<列名> 數據類(lèi)型 [缺省值] [NOT NULL / NULL] [,<列名> 數據類(lèi)型[缺省值][NOT NULL / NULL]]...... [,UNIQUE (列名[,列名]......)] [,PRIMARY KEY(列名)] [,FOREIGN KEY(列名[,列名]......) REFERENCE <表名>(列名[,列名]......)] [,CHECK(條件)][其它參數]) 例如:在基本表student中加入列stborn出生日期,數據類(lèi)型為DATE,且不能為空值 ALTER TABLE student ADD (stborn DATE NOT NULL) 刪除屬性的語(yǔ)句格式為: ALTER TABLE [<數據庫名>.]表名 DROP ( <列名> 數據類(lèi)型 [缺省值][NOT NULL / NULL] [,<列名> 數據類(lèi)型 [缺省值][NOT NULL / NULL]]......) 例如:將基本表student中的列st_age刪除 ALTER TABLE student DROP (st_age) 3.視圖定義與刪除 在SQL中,視圖是外模式一級數據結構的基本單位。它是從一個(gè)或幾個(gè)基本表中導出的表,是從現有基本表中抽取若干子集組成用戶(hù)的“專(zhuān)用表”。這種構造方式必須使用SQL中的SELECT語(yǔ)句來(lái)實(shí)現。在定義一個(gè)視圖時(shí),只是把其定義存放在系統的數據中,而并不直接存儲視圖對應的數據,直到用戶(hù)使用視圖時(shí)才去求得對應的數據。 (1)視圖的定義:定義視圖可以使用CREATE VIEW語(yǔ)句實(shí)現,其語(yǔ)句格式為: CREATE VIEW 視圖名 AS SELECT語(yǔ)句 從一個(gè)基本表中導出視圖: 例:從基本表student中導出只包括女學(xué)生情況的視圖 CREATE VIEW WOMANVIEW AS //創(chuàng )建一個(gè)視圖WOMANVIEW SELECT st_class,st_no,st_name,st_age //選擇列st_class,st_no,st_name,st_age顯示 FROM student //從基本表student引入 WHERE st_sex=‘女’//引入條件為性別為“女”,注意字符變量都使用單引號引用 從多個(gè)基本表中導出視圖: 例如:從基本表student和score中導出只包括女學(xué)生且分數在60分以上的視圖 CREATEVIEW WOMAN_SCORE AS //定義視圖WOMANSCORE SELECT student.st_class,student.st_no,student.st_name,student.st_age,score.sc_score //有選擇性顯示相關(guān)列 FROM student.score //從基本表student和score中引入 WHERE student.st_sex=‘女’AND score.sc_score>=60 AND student.st_no=score.st_no //選擇條件:性別為“女” 且分數在60分以上。并使用st_no將兩表聯(lián)系起來(lái)。 以后如果進(jìn)行這一視圖的應用,則只需使用語(yǔ)句 SELECT * FROM WOMAN_SCORE //其中“*”為通配符,代表所有元素 (2)視圖的刪除:用于刪除已不再使用的視圖,其語(yǔ)句格式如下: DROP VIEW 視圖名 例:將上面建立的WOMAN_SCORE視圖刪除 DROP VIEW WOMAN_SCORE 4.索引的定義與刪除 索引屬于物理存儲概念,而不是邏輯的概念。在SQL中拋棄了索引概念,直接使用主鍵概念。值得一提的是,有些關(guān)系DBMS同時(shí)包括索引機制和主鍵機制,這里我們推薦使用主鍵機制,因為它對系統資源占用較低且效率較高。 (1)索引的定義:索引是建立在基本表之上的,其語(yǔ)句格式為: CREATE [UNIQUE] INDEX 索引名 ON [<數據庫名>.]表名(列名 [ASC/DESC][,列名 [ASC/DESC]]......) 這里,保留字UNIQUE表示基本表中的索引值不允許重復,若缺省則表示索引值在表中允許重復;DESC表示按索引鍵降序排列,若缺省或ASC表示升序排列。 例:對基本表student中的st_no和st_age建立索引,分別為升序與降序,且索引值不允許重復 CREATE UNIQUE INDEX STINDEX ON//創(chuàng )建索引STINDEX student(st_no ASC,st_age DESC)//對student中的st_no和st_age建立索引 (2)索引的刪除: DROP INDEX 索引名 例:刪除上面建立的索引STINDEX DROP INDEX STINDEX ##2 (二)數據查詢(xún) SQL是一種查詢(xún)功能很強的語(yǔ)言,只要是數據庫存在的數據,總能通過(guò)適當的方法將它從數據庫中查找出來(lái)。SQL中的查詢(xún)語(yǔ)句只有一個(gè):SELECT,它可與其它語(yǔ)句配合完成所有的查詢(xún)功能。SELECT語(yǔ)句的完整語(yǔ)法,可以有6個(gè)子句。完整的語(yǔ)法如下: SELECT 目標表的列名或列表達式集合 FROM 基本表或(和)視圖集合 [WHERE條件表達式] [GROUP BY列名集合 [HAVING組條件表達式]] [ORDER BY列名[集合]…] 整個(gè)語(yǔ)句的語(yǔ)義如下:從FROM子句中列出的表中,選擇滿(mǎn)足WHERE子句中給出的條件表達式的元組,然后按GROUPBY子句(分組子句)中指定列的值分組,再提取滿(mǎn)足HAVING子句中組條件表達式的那些組,按SELECT子句給出的列名或列表達式求值輸出。ORDER子句(排序子句)是對輸出的目標表進(jìn)行重新排序,并可附加說(shuō)明ASC(升序)或DESC(降序)排列。 在WHERE子句中的條件表達式F中可出現下列操作符和運算函數: 算術(shù)比較運算符:<,<=,>,>=,=,<>。 邏輯運算符:AND,OR,NOT。 集合運算符:UNION(并),INTERSECT(交),EXCEPT(差)。 集合成員資格運算符:IN,NOT IN 謂詞:EXISTS(存在量詞),ALL,SOME,UNIQUE。 聚合函數:AVG(平均值),MIN(最小值),MAX(最大值),SUM(和),COUNT(計數)。 F中運算對象還可以是另一個(gè)SELECT語(yǔ)句,即SELECT語(yǔ)句可以嵌套。 上面只是列出了WHERE子句中可出現的幾種主要操作,由于WHERE子句中的條件表達式可以很復雜,因此SELECT句型能表達的語(yǔ)義遠比其數學(xué)原形要復雜得多。 下面,我們以上面所建立的三個(gè)基本表為例,演示一下SELECT的應用: 1.無(wú)條件查詢(xún) 例:找出所有學(xué)生的的選課情況 SELECT st_no,su_no FROM score 例:找出所有學(xué)生的情況 SELECT* FROM student “*”為通配符,表示查找FROM中所指出關(guān)系的所有屬性的值。 2.條件查詢(xún) 條件查詢(xún)即帶有WHERE子句的查詢(xún),所要查詢(xún)的對象必須滿(mǎn)足WHERE子句給出的條件。 例:找出任何一門(mén)課成績(jì)在70以上的學(xué)生情況、課號及分數 SELECT UNIQUE student.st_class,student.st_no,student.st_name,student.st_sex,student.st_age,score.su_no,score.score FROM student,score WHERE score.score>=70 AND score.stno=student.st_no 這里使用UNIQUE是不從查詢(xún)結果集中去掉重復行,如果使用DISTINCT則會(huì )去掉重復行。另外邏輯運算符的優(yōu)先順序為NOT→AND→OR。 例:找出課程號為c02的,考試成績(jì)不及格的學(xué)生 SELECT st_no FROM score WHERE su_no=‘c02’AND score<60 3.排序查詢(xún) 排序查詢(xún)是指將查詢(xún)結果按指定屬性的升序(ASC)或降序(DESC)排列,由ORDER BY子句指明。 例:查找不及格的課程,并將結果按課程號從大到小排列 SELECT UNIQUE su_no FROM score WHERE score<60 ORDER BY su_no DESC 4.嵌套查詢(xún) 嵌套查詢(xún)是指WHERE子句中又包含SELECT子句,它用于較復雜的跨多個(gè)基本表查詢(xún)的情況。 例:查找課程編號為c03且課程成績(jì)在80分以上的學(xué)生的學(xué)號、姓名 SELECT st_no,st_name FROM student WHERE stno IN (SELECT st_no FROM score WHERE su_no=‘c03’ AND score>80 ) 這里需要明確的是:當查詢(xún)涉及多個(gè)基本表時(shí)用嵌套查詢(xún)逐次求解層次分明,具有結構程序設計特點(diǎn)。在嵌套查詢(xún)中,IN是常用到的謂詞。若用戶(hù)能確切知道內層查詢(xún)返回的是單值,那么也可用算術(shù)比較運算符表示用戶(hù)的要求。 5.計算查詢(xún) 計算查詢(xún)是指通過(guò)系統提供的特定函數(聚合函數)在語(yǔ)句中的直接使用而獲得某些只有經(jīng)過(guò)計算才能得到的結果。常用的函數有: COUNT(*) 計算元組的個(gè)數 COUNT(列名) 對某一列中的值計算個(gè)數 SUM(列名) 求某一列值的總和(此列值是數值型) AVG(列名) 求某一列值的平均值(此列值是數值型) MAX(列名) 求某一列值中的最大值 MIN(列名) 求某一列值中的最小值 例:求男學(xué)生的總人數和平均年齡 SELECT COUNT(*),AVG(st_age) FROM student WHERE st_sex=‘男’ 例:統計選修了課程的學(xué)生的人數 SELECT COUNT(DISTINCT st_no) FROM score 注意:這里一定要加入DISTINCT,因為有的學(xué)生可能選修了多門(mén)課程,但統計時(shí)只能按1人統計,所以要使用DISTINCT進(jìn)行過(guò)濾。 ##2 (三) 數據更新 數據更新包括數據插入、刪除和修改操作。它們分別由INSERT語(yǔ)句,DELETE語(yǔ)句及UPDATE語(yǔ)句完成。這些操作都可在任何基本表上進(jìn)行,但在視圖上有所限制。其中,當視圖是由單個(gè)基本表導出時(shí),可進(jìn)行插入和修改操作,但不能進(jìn)行刪除操作;當視圖是從多個(gè)基本表中導出時(shí),上述三種操作都不能進(jìn)行。 1.數據插入 將數據插入SQL的基本表有兩種方式:一種是單元組的插入,另一種是多元組的插入。 單元組的插入:向基本表score中插入一個(gè)成績(jì)元組(100002,c02,95),可使用以下語(yǔ)句: INSERT INTO score(st_no,su_no,score) VALUES(‘100002’,‘c02’,95) 由此,可以給出單元組的插入語(yǔ)句格式: INSERT INTO表名(列名1[,列名2]…) VALUES(列值1[,列值2]…) 其中,列名序列為要插入值的列名集合,列值序列為要插入的對應值。若插入的是一個(gè)表的全部列值,則列名可以省略不寫(xiě)如上面的(st_no,su_no,score)可以省去;若插入的是表的部分列值,則必須列出相應列名,此時(shí),該關(guān)系中未列出的列名取空值。 多元組的插入:這是一種把SELECT語(yǔ)句查詢(xún)結果插入到某個(gè)已知的基本表中的方法。 例如:需要在表score中求出每個(gè)學(xué)生的平均成績(jì),并保留在某個(gè)表中。此時(shí)可以先創(chuàng )建一個(gè)新的基本表stu_avggrade,再用INSERT語(yǔ)句把表score中求得的每一個(gè)學(xué)生的平均成績(jì)(用SELECT求得)插入至stu_avggrade中。 CREATE TABLE stu_avggrade (st_no CHAR(10) NOT NULL,//定義列st_no學(xué)號,類(lèi)型為10位定長(cháng)字符串,非空 age_grade SMALLINT NOT NULL )// 定義列age_grade平均分,類(lèi)型為短整形,非空 INSERT INTO stu_avggrade(st_no,age_grade) SELECT st_no,AVG(score) FROM score GROUP BY st_no //因為要求每一個(gè)學(xué)生所有課程的平均成績(jì),必須按學(xué)號分組進(jìn)行計算。 2.數據刪除 SQL的刪除操作是指從基本表中刪除滿(mǎn)足WHERE<條件表達式>的記錄。如果沒(méi)有WHERE子句,則刪除表中全部記錄,但表結構依然存在。其語(yǔ)句格式為: DELETE FROM表名[WHERE 條件表達式] 下面舉例說(shuō)明: 單元組的刪除:把學(xué)號為100002的學(xué)生從表student中刪除,可用以下語(yǔ)句: DELETE FROM student WHERE st_no=‘100002’//因為學(xué)號為100002的學(xué)生在表student中只有一個(gè),所以為單元組的刪除 多元組的刪除:學(xué)號為100002的成績(jì)從表score中刪除,可用以下語(yǔ)句: DELETE FROM score WHERE st_no=‘100002’//由于學(xué)號為100002的元組在表score中可能有多個(gè),所以為多元組刪除 帶有子查詢(xún)的刪除操作:刪除所有不及格的學(xué)生記錄,可用以下語(yǔ)句 DELETE FROM student WHERE st_no IN (SELETE st_no FROM score WHERE score<60) 3.數據修改 修改語(yǔ)句是按SET子句中的表達式,在指定表中修改滿(mǎn)足條件表達式的記錄的相應列值。其語(yǔ)句格式如下: UPDATE 表名 SET 列名=列改變值[WHERE 條件表達式] 例:把c02的課程名改為英語(yǔ),可以用下列語(yǔ)句: UPDATE subject SET su_subject=‘英語(yǔ)’ WHERE su_no=‘c02’ 例:將課程成績(jì)達到70分的學(xué)生成績(jì),再提高10% UPDATE score SET score=1.1*score WHERE score>=70 SQL的刪除語(yǔ)句和修改語(yǔ)句中的WHERE子句用法與SELECT中WHERE子句用法相同。數據的刪除和修改操作,實(shí)際上要先做SELECT查詢(xún)操作,然后再把找到的元組刪除或修改。 ##2 (四) 數據控制 由于數據庫管理系統是一個(gè)多用戶(hù)系統,為了控制用戶(hù)對數據的存取權利,保持數據的共享及完全性,SQL語(yǔ)言提供了一系列的數據控制功能。其中,主要包括安全性控制、完整性控制、事務(wù)控制和并發(fā)控制。 1.安全性控制 數據的安全性是指保護數據庫,以防非法使用造成數據泄露和破壞。保證數據安全性的主要方法是通過(guò)對數據庫存取權力的控制來(lái)防止非法使用數據庫中的數據。即限定不同用戶(hù)操作不同的數據對象的權限。 存取權控制包括權力的授與、檢查和撤消。權力授與和撤消命令由數據庫管理員或特定應用人員使用。系統在對數據庫操作前,先核實(shí)相應用戶(hù)是否有權在相應數據上進(jìn)行所要求的操作。 (1)權力授與:權力授與有數據庫管理員專(zhuān)用的授權和用戶(hù)可用的授權兩種形式。數據庫管理員專(zhuān)用授權命令格式如下: |CONNECT | GRANT|RESOURCE|TO 用戶(hù)名[IDENTIFED BY 口令] |DBA | 其中,CONNECT表示數據庫管理員允許指定的用戶(hù)具有連接到數據庫的權力,這種授權是針對新用戶(hù);RESOURCE表示允許用戶(hù)建立自己的新關(guān)系模式,用戶(hù)獲得CONNECT權力后,必須獲得RESOURCE權力才能創(chuàng )建自己的新表;DBA表示數據庫管理員將自己的特權授與指定的用戶(hù)。若要同時(shí)授與某用戶(hù)上述三種授權中的多種權力,則必須通過(guò)三個(gè)相應的GRANT命令指定。 另外,具有CONNECT和RESOURCE授權的用戶(hù)可以建立自己的表,并在自己建立的表和視圖上具有查詢(xún)、插入、修改和刪除的權力。但通常不能使用其他用戶(hù)的關(guān)系,除非能獲得其他用戶(hù)轉授給他的相應權力。 例:若允許用戶(hù)SSE連接到數據庫并可以建立他自己的關(guān)系,則可通過(guò)如下命令授與權力: GRANT CONNECT TO SSE INENTIFIED BY BD1928 GRANT RESOURCE TO SSE 用戶(hù)可用的授權是指用戶(hù)將自己擁有的部分或全部權力轉授給其他用戶(hù)的命令形式,其命令格式如下: |SELECT | |INSERT | |DELETE | GRANT|UPDATE(列名1[,列名2]…)|ON|表名 |TO|用戶(hù)名|[WITH GRANT OPTION] |ALTER | |視圖名| |PUBLIC| |NDEX | |ALL | 若對某一用戶(hù)同時(shí)授與多種操作權力,則操作命令符號可用“,”相隔。 PUBLIC 表示將權力授與數據庫的所有用戶(hù),使用時(shí)要注意: 任選項WITH GRANT OPTION表示接到授權的用戶(hù),具有將其所得到的同時(shí)權力再轉授給其他用戶(hù)權力。 例:如果將表student的查詢(xún)權授與所有用戶(hù),可使用以下命令: GRANT SELECT ON student TO PUBLIC 例:若將表subject的插入及修改權力授與用戶(hù)SSE并使得他具有將這種權力轉授他人的權力,則可使用以下命令: GRANT INSERT,UPDATE(su_subject) ON subject TO SSE WITH GRANT OPTION 這里,UPDATE后面跟su_subject是指出其所能修改的列。 (2)權力回收:權力回收是指回收指定用戶(hù)原已授與的某些權力。與權力授與命令相匹配,權力回收也有數據庫管理員專(zhuān)用和用戶(hù)可用的兩種形式。 DBA專(zhuān)用的權力回收命令格式為: |CONNECT | REVOKE|RESOURCE|FROM用戶(hù)名 |DBA | 用戶(hù)可用的權力回收命令格式為: |SELECT | |INSERT | |DELETE | REVOKE|UPDATE(列名1[,列名2]…) |ON|表名 |FROM |用戶(hù)名| |ALTER | |視圖名| |PUBLIC| |INDEX | |ALL | 例:回收用戶(hù)SSE的DBA權力: REVOKE DBA FROM SSE 2.完整性控制 數據庫的完整性是指數據的正確性和相容性,這是數據庫理論中的重要概念。完整性控制的主要目的是防止語(yǔ)義上不正確的數據進(jìn)入數據庫。關(guān)系系統中的完整性約束條件包括實(shí)體完整性、參照完整性和用戶(hù)定義完整性。而完整性約束條件的定義主要是通過(guò)CREATE TABLE語(yǔ)句中的[CHECK]子句來(lái)完成。另外,還有一些輔助命令可以進(jìn)行數據完整性保護。如UNIQUE和NOT NULL,前者用于防止重復值進(jìn)入數據庫,后者用于防止空值。 3.事務(wù)控制 事務(wù)是并發(fā)控制的基本單位,也是恢復的基本單位。在SQL中支持事務(wù)的概念。所謂事務(wù),是用戶(hù)定義的一個(gè)操作序列(集合),這些操作要么都做,要么一個(gè)都不做,是一個(gè)不可分割的整體。一個(gè)事務(wù)通常以BEGIN TRANSACTION開(kāi)始,以COMMIT或ROLLBACK結束。 SQL提供了事務(wù)提交和事務(wù)撤消兩種命令: (1)事務(wù)提交:事務(wù)提交的命令為: COMMIT [WORK] 事務(wù)提交標志著(zhù)對數據庫的某種應用操作成功地完成,所有對數據庫的操作都必須作為事務(wù)提交給系統時(shí)才有效。事務(wù)一經(jīng)提交就不能撤消。 (2)事務(wù)撤消:事務(wù)撤消的命令是: ROLLBACK [WORK] 事務(wù)撤消標志著(zhù)相應事務(wù)對數據庫操作失敗,因而要撤消對數據庫的改變,即要“回滾”到相應事務(wù)開(kāi)始時(shí)的狀態(tài)。 當系統非正常結束時(shí)(如掉電、系統死機),將自動(dòng)執行ROLLBACK命令 SQL還提供了自動(dòng)提交事務(wù)的機制,其命令為: SET AUTO COMMIT ON 其對應的人工工作方式命令為: SET AUTO COMMIT OFF 一旦規定了自動(dòng)提交事務(wù)方式,則系統將每條SQL命令視為一個(gè)事務(wù),并在命令成功執行完成時(shí)自動(dòng)地完成事務(wù)提交。 4.并發(fā)控制 數據庫作為共享資源,允許多個(gè)用戶(hù)程序并行地存取數據。當多個(gè)用戶(hù)并行地操作數據庫時(shí),需要通過(guò)并發(fā)控制對它們加以協(xié)調、控制,以保證并發(fā)操作的正確執行,并保證數據庫的一致性。 在SQL中,并發(fā)控制采用封鎖技術(shù)實(shí)現,當一個(gè)事務(wù)欲對某個(gè)數據對象操作時(shí),可申請對該對象加鎖,取得對數據對象的一定控制,以限制其他事務(wù)對該對象的操作。其語(yǔ)句格式為: |SHARE | LOCK TABLE 表名(或表名集合)IN |EXCLUSVE |MODE [NOWAIT] |SHARE UPDATE| 其中,表名(或表名集合)中指出封鎖對象,若為多個(gè)表名,則各個(gè)表名間以“,”相隔;任選項NOWAIT表示多個(gè)用戶(hù)要求封鎖相同的關(guān)系時(shí),后來(lái)提出的要求會(huì )被立即退回去,否則會(huì )等待該資源釋放。 SHARE表示共享封鎖方式;EXCLUSIVE表示獨占封鎖方式;SHARE UPDAE表示共享更新封鎖方式。其中共享封鎖方式允許其他事務(wù)讀同一數據,但防止其他事務(wù)對已封鎖的表進(jìn)行更新,該鎖主要防止在表的兩次查詢(xún)之間對該表的改動(dòng);共享更新封鎖SHARE UPDATE是一個(gè)行封鎖機制,它可改善表級封鎖的并行性,它能允許并發(fā)事務(wù)讀和修改一個(gè)表中的不同的行;獨占封鎖方式EXCLUSIVE禁止其他事務(wù)獲得一個(gè)共享鎖且禁止其他事務(wù)執行任何數據操作語(yǔ)句,即一旦某個(gè)運行事務(wù)對某個(gè)數據對象施加了排它鎖,則其他任何事務(wù)都不能再對該數據對象施加任何方式的鎖,只有處于等待狀態(tài)。如果不想無(wú)限等待,則選擇NOWAIT。 PHP(Hypertext Preprocessor,超文本預處理器)是一個(gè)遞歸的縮寫(xiě)名稱(chēng),它是一種內嵌在HTML頁(yè)面內的腳本語(yǔ)言。它的功能強大,使用方便,開(kāi)發(fā)難度不大,而且可以免費使用。 |
聯(lián)系客服