我的人生路  
          日歷
          <2005年7月>
          262728293012
          3456789
          10111213141516
          17181920212223
          24252627282930
          31123456
          統(tǒng)計
          • 隨筆 - 74
          • 文章 - 57
          • 評論 - 7
          • 引用 - 0

          導(dǎo)航

          常用鏈接

          留言簿(5)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          相冊

          顏色

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

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

          若對某一用戶同時授與多種操作權(quán)力,則操作命令符號可用“,”相隔。
          PUBLIC 表示將權(quán)力授與數(shù)據(jù)庫的所有用戶,使用時要注意:
          任選項WITH GRANT OPTION表示接到授權(quán)的用戶,具有將其所得到的同時權(quán)力再轉(zhuǎn)授給其他用戶權(quán)力。
          例:如果將表student的查詢權(quán)授與所有用戶,可使用以下命令:
          GRANT SELECT ON student TO PUBLIC
          例:若將表subject的插入及修改權(quán)力授與用戶SSE并使得他具有將這種權(quán)力轉(zhuǎn)授他人的權(quán)力,則可使用以下命令:
          GRANT INSERT,UPDATE(su_subject) ON subject TO SSE WITH GRANT OPTION
          這里,UPDATE后面跟su_subject是指出其所能修改的列。
          (2)權(quán)力回收:權(quán)力回收是指回收指定用戶原已授與的某些權(quán)力。與權(quán)力授與命令相匹配,權(quán)力回收也有數(shù)據(jù)庫管理員專用和用戶可用的兩種形式。
          DBA專用的權(quán)力回收命令格式為:
          |CONNECT |
          REVOKE|RESOURCE|FROM用戶名
          |DBA |
          用戶可用的權(quán)力回收命令格式為:
          |SELECT |
          |INSERT |
          |DELETE |
          REVOKE|UPDATE(列名1[,列名2]…) |ON|表名 |FROM |用戶名|
          |ALTER | |視圖名| |PUBLIC|
          |INDEX |
          |ALL |
          例:回收用戶SSE的DBA權(quán)力:
          REVOKE DBA FROM SSE
          2.完整性控制
          數(shù)據(jù)庫的完整性是指數(shù)據(jù)的正確性和相容性,這是數(shù)據(jù)庫理論中的重要概念。完整性控制的主要目的是防止語義上不正確的數(shù)據(jù)進(jìn)入數(shù)據(jù)庫。關(guān)系系統(tǒng)中的完整性約束條件包括實體完整性、參照完整性和用戶定義完整性。而完整性約束條件的定義主要是通過CREATE TABLE語句中的[CHECK]子句來完成。另外,還有一些輔助命令可以進(jìn)行數(shù)據(jù)完整性保護(hù)。如UNIQUE和NOT NULL,前者用于防止重復(fù)值進(jìn)入數(shù)據(jù)庫,后者用于防止空值。
          3.事務(wù)控制
          事務(wù)是并發(fā)控制的基本單位,也是恢復(fù)的基本單位。在SQL中支持事務(wù)的概念。所謂事務(wù),是用戶定義的一個操作序列(集合),這些操作要么都做,要么一個都不做,是一個不可分割的整體。一個事務(wù)通常以BEGIN TRANSACTION開始,以COMMIT或ROLLBACK結(jié)束。
          SQL提供了事務(wù)提交和事務(wù)撤消兩種命令:
          (1)事務(wù)提交:事務(wù)提交的命令為:
          COMMIT [WORK]
          事務(wù)提交標(biāo)志著對數(shù)據(jù)庫的某種應(yīng)用操作成功地完成,所有對數(shù)據(jù)庫的操作都必須作為事務(wù)提交給系統(tǒng)時才有效。事務(wù)一經(jīng)提交就不能撤消。
          (2)事務(wù)撤消:事務(wù)撤消的命令是:
          ROLLBACK [WORK]
          事務(wù)撤消標(biāo)志著相應(yīng)事務(wù)對數(shù)據(jù)庫操作失敗,因而要撤消對數(shù)據(jù)庫的改變,即要“回滾”到相應(yīng)事務(wù)開始時的狀態(tài)。
          當(dāng)系統(tǒng)非正常結(jié)束時(如掉電、系統(tǒng)死機(jī)),將自動執(zhí)行ROLLBACK命令
          SQL還提供了自動提交事務(wù)的機(jī)制,其命令為:
          SET AUTO COMMIT ON
          其對應(yīng)的人工工作方式命令為:
          SET AUTO COMMIT OFF
          一旦規(guī)定了自動提交事務(wù)方式,則系統(tǒng)將每條SQL命令視為一個事務(wù),并在命令成功執(zhí)行完成時自動地完成事務(wù)提交。
          4.并發(fā)控制
          數(shù)據(jù)庫作為共享資源,允許多個用戶程序并行地存取數(shù)據(jù)。當(dāng)多個用戶并行地操作數(shù)據(jù)庫時,需要通過并發(fā)控制對它們加以協(xié)調(diào)、控制,以保證并發(fā)操作的正確執(zhí)行,并保證數(shù)據(jù)庫的一致性。
          在SQL中,并發(fā)控制采用封鎖技術(shù)實現(xiàn),當(dāng)一個事務(wù)欲對某個數(shù)據(jù)對象操作時,可申請對該對象加鎖,取得對數(shù)據(jù)對象的一定控制,以限制其他事務(wù)對該對象的操作。其語句格式為:
          |SHARE |
          LOCK TABLE 表名(或表名集合)IN |EXCLUSVE |MODE [NOWAIT]
          |SHARE UPDATE|
          其中,表名(或表名集合)中指出封鎖對象,若為多個表名,則各個表名間以“,”相隔;任選項NOWAIT表示多個用戶要求封鎖相同的關(guān)系時,后來提出的要求會被立即退回去,否則會等待該資源釋放。
          SHARE表示共享封鎖方式;EXCLUSIVE表示獨占封鎖方式;SHARE UPDAE表示共享更新封鎖方式。其中共享封鎖方式允許其他事務(wù)讀同一數(shù)據(jù),但防止其他事務(wù)對已封鎖的表進(jìn)行更新,該鎖主要防止在表的兩次查詢之間對該表的改動;共享更新封鎖SHARE UPDATE是一個行封鎖機(jī)制,它可改善表級封鎖的并行性,它能允許并發(fā)事務(wù)讀和修改一個表中的不同的行;獨占封鎖方式EXCLUSIVE禁止其他事務(wù)獲得一個共享鎖且禁止其他事務(wù)執(zhí)行任何數(shù)據(jù)操作語句,即一旦某個運行事務(wù)對某個數(shù)據(jù)對象施加了排它鎖,則其他任何事務(wù)都不能再對該數(shù)據(jù)對象施加任何方式的鎖,只有處于等待狀態(tài)。如果不想無限等待,則選擇NOWAIT。
          PHP(Hypertext Preprocessor,超文本預(yù)處理器)是一個遞歸的縮寫名稱,它是一種內(nèi)嵌在HTML頁面內(nèi)的腳本語言。它的功能強(qiáng)大,使用方便,開發(fā)難度不大,而且可以免費使用。


          SQL語法參考手冊

          日期:2000-9-14 15:41:00
          出處:未知
          作者:未知

          DB2 提供了關(guān)連式資料庫的查詢語言 SQL (Structured Query Language),是一種非常口語化、既易學(xué)又易懂的語法。 此一語言幾乎是每個資料庫系統(tǒng)都必須提供的,用以表示關(guān)連式的操作,包含了資料的定義(DDL)以及資料的處理(DML)。SQL原來拼成SEQUEL,這語言的原型以“系統(tǒng) R“的名字在 IBM 圣荷西實驗室完成,經(jīng)過IBM內(nèi)部及其他的許多使用性及效率測試,其結(jié)果相當(dāng)令人滿意,并決定在系統(tǒng)R 的技術(shù)基礎(chǔ)發(fā)展出來 IBM 的產(chǎn)品。而且美國國家標(biāo)準(zhǔn)學(xué)會(ANSI)及國際標(biāo)準(zhǔn)化組織(ISO)在1987遵循一個幾乎是以 IBM SQL 為基礎(chǔ)的標(biāo)準(zhǔn)關(guān)連式資料語言定義。

          一、資料定義 DDL(Data Definition Language)
          資料定語言是指對資料的格式和形態(tài)下定義的語言,他是每個資料庫要建立時候時首先要面對的,舉凡資料分哪些表格關(guān)系、表格內(nèi)的有什麼欄位主鍵、表格和表格之間互相參考的關(guān)系等等,都是在開始的時候所必須規(guī)劃好的。

          1、建表格:
          CREATE TABLE table_name(
          column1 DATATYPE [NOT NULL] [NOT NULL PRIMARY KEY],
          column2 DATATYPE [NOT NULL],
          ...)
          說明: 
          DATATYPE --是資料的格式,詳見表。
          NUT NULL --可不可以允許資料有空的(尚未有資料填入)。
          PRIMARY KEY --是本表的主鍵。

          2、更改表格 
          ALTER TABLE table_name
          ADD COLUMN column_name DATATYPE
          說明:增加一個欄位(沒有刪除某個欄位的語法。
          ALTER TABLE table_name
          ADD PRIMARY KEY (column_name)
          說明:更改表得的定義把某個欄位設(shè)為主鍵。
          ALTER TABLE table_name
          DROP PRIMARY KEY (column_name)
          說明:把主鍵的定義刪除。

          3、建立索引 
          CREATE INDEX index_name ON table_name (column_name)
          說明:對某個表格的欄位建立索引以增加查詢時的速度。

          4、刪除 
          DROP table_name
          DROP index_name

          二、的資料形態(tài) DATATYPEs
          smallint
          16 位元的整數(shù)。
          interger
          32 位元的整數(shù)。
          decimal(p,s)
          p 精確值和 s 大小的十進(jìn)位整數(shù),精確值p是指全部有幾個數(shù)(digits)大小值,s是指小數(shù)
          點後有幾位數(shù)。如果沒有特別指定,則系統(tǒng)會設(shè)為 p=5; s=0 。
          float
          32位元的實數(shù)。
          double
          64位元的實數(shù)。
          char(n)
          n 長度的字串,n不能超過 254。
          varchar(n)
          長度不固定且其最大長度為 n 的字串,n不能超過 4000。
          graphic(n)
          和 char(n) 一樣,不過其單位是兩個字元 double-bytes, n不能超過127。這個形態(tài)是為
          了支援兩個字元長度的字體,例如中文字。
          vargraphic(n)
          可變長度且其最大長度為 n 的雙字元字串,n不能超過 2000。
          date
          包含了 年份、月份、日期。
          time
          包含了 小時、分鐘、秒。
          timestamp
          包含了 年、月、日、時、分、秒、千分之一秒。

          三、資料操作 DML (Data Manipulation Language)
          資料定義好之後接下來的就是資料的操作。資料的操作不外乎增加資料(insert)、查詢資料(query)、更改資料(update) 、刪除資料(delete)四種模式,以下分 別介紹他們的語法:

          1、增加資料:
          INSERT INTO table_name (column1,column2,...)
          VALUES ( value1,value2, ...)
          說明:
          1.若沒有指定column 系統(tǒng)則會按表格內(nèi)的欄位順序填入資料。
          2.欄位的資料形態(tài)和所填入的資料必須吻合。
          3.table_name 也可以是景觀 view_name。

          INSERT INTO table_name (column1,column2,...)
          SELECT columnx,columny,... FROM another_table
          說明:也可以經(jīng)過一個子查詢(subquery)把別的表格的資料填入。

          2、查詢資料:
          基本查詢
          SELECT column1,columns2,...
          FROM table_name
          說明:把table_name 的特定欄位資料全部列出來
          SELECT *
          FROM table_name
          WHERE column1 = xxx
          [AND column2 > yyy] [OR column3 <> zzz]
          說明:
          1.'*'表示全部的欄位都列出來。
          2.WHERE 之後是接條件式,把符合條件的資料列出來。

          SELECT column1,column2
          FROM table_name
          ORDER BY column2 [DESC]
          說明:ORDER BY 是指定以某個欄位做排序,[DESC]是指從大到小排列,若沒有指明,則是從小到大
          排列

          組合查詢
          組合查詢是指所查詢得資料來源并不只有單一的表格,而是聯(lián)合一個以上的
          表格才能夠得到結(jié)果的。
          SELECT *
          FROM table1,table2
          WHERE table1.colum1=table2.column1
          說明:
          1.查詢兩個表格中其中 column1 值相同的資料。
          2.當(dāng)然兩個表格相互比較的欄位,其資料形態(tài)必須相同。
          3.一個復(fù)雜的查詢其動用到的表格可能會很多個。

          整合性的查詢:
          SELECT COUNT (*)
          FROM table_name
          WHERE column_name = xxx
          說明:
          查詢符合條件的資料共有幾筆。
          SELECT SUM(column1)
          FROM table_name
          說明:
          1.計算出總和,所選的欄位必須是可數(shù)的數(shù)字形態(tài)。
          2.除此以外還有 AVG() 是計算平均、MAX()、MIN()計算最大最小值的整合性查詢。
          SELECT column1,AVG(column2)
          FROM table_name
          GROUP BY column1
          HAVING AVG(column2) > xxx
          說明:
          1.GROUP BY: 以column1 為一組計算 column2 的平均值必須和 AVG、SUM等整合性查詢的關(guān)鍵字
          一起使用。
          2.HAVING : 必須和 GROUP BY 一起使用作為整合性的限制。

          復(fù)合性的查詢
          SELECT *
          FROM table_name1
          WHERE EXISTS (
          SELECT *
          FROM table_name2
          WHERE conditions )
          說明:
          1.WHERE 的 conditions 可以是另外一個的 query。
          2.EXISTS 在此是指存在與否。
          SELECT *
          FROM table_name1
          WHERE column1 IN (
          SELECT column1
          FROM table_name2
          WHERE conditions )
          說明: 
          1. IN 後面接的是一個集合,表示column1 存在集合里面。
          2. SELECT 出來的資料形態(tài)必須符合 column1。

          其他查詢
          SELECT *
          FROM table_name1
          WHERE column1 LIKE 'x%'
          說明:LIKE 必須和後面的'x%' 相呼應(yīng)表示以 x為開頭的字串。
          SELECT *
          FROM table_name1
          WHERE column1 IN ('xxx','yyy',..)
          說明:IN 後面接的是一個集合,表示column1 存在集合里面。
          SELECT *
          FROM table_name1
          WHERE column1 BETWEEN xx AND yy
          說明:BETWEEN 表示 column1 的值介於 xx 和 yy 之間。

          3、更改資料:
          UPDATE table_name
          SET column1='xxx'
          WHERE conditoins
          說明:
          1.更改某個欄位設(shè)定其值為'xxx'。
          2.conditions 是所要符合的條件、若沒有 WHERE 則整個 table 的那個欄位都會全部被更改。

          4、刪除資料:
          DELETE FROM table_name
          WHERE conditions
          說明:刪除符合條件的資料。

          說明:關(guān)于WHERE條件后面如果包含有日期的比較,不同數(shù)據(jù)庫有不同的表達(dá)式。具體如下:
          (1)如果是ACCESS數(shù)據(jù)庫,則為:WHERE mydate>#2000-01-01#
          (2)如果是ORACLE數(shù)據(jù)庫,則為:WHERE mydate>cast('2000-01-01' as date)
          或:WHERE mydate>to_date('2000-01-01','yyyy-mm-dd')
          在Delphi中寫成:
          thedate= '2000-01-01';
          query1.SQL.add('select * from abc where mydate>cast('+''+thedate+''+' as date)');

          如果比較日期時間型,則為:
          WHERE mydatetime>to_date('2000-01-01 10:00:01','yyyy-mm-dd hh24:mi:ss')



          歡迎大家訪問我的個人網(wǎng)站 萌萌的IT人
          posted on 2005-07-14 16:52 一天一點愛戀 閱讀(788) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
           
          Copyright © 一天一點愛戀 Powered by: 博客園 模板提供:滬江博客
          主站蜘蛛池模板: 易门县| 石嘴山市| 黄平县| 襄垣县| 无锡市| 民县| 攀枝花市| 盐池县| 吴川市| 宁强县| 台东市| 台东县| 深水埗区| 新丰县| 门头沟区| 佳木斯市| 隆回县| 抚州市| 宁波市| 五大连池市| 梁山县| 海原县| 保山市| 金山区| 伊通| 霞浦县| 额尔古纳市| 铜山县| 双流县| 精河县| 凤凰县| 嘉峪关市| 广安市| 包头市| 塘沽区| 福贡县| 新河县| 东明县| 青阳县| 天峨县| 团风县|