數(shù)據(jù)庫(kù)原理及應(yīng)用第二版第3章 SQL語(yǔ)言基礎(chǔ)及數(shù)據(jù)定義功能_第1頁(yè)
數(shù)據(jù)庫(kù)原理及應(yīng)用第二版第3章 SQL語(yǔ)言基礎(chǔ)及數(shù)據(jù)定義功能_第2頁(yè)
數(shù)據(jù)庫(kù)原理及應(yīng)用第二版第3章 SQL語(yǔ)言基礎(chǔ)及數(shù)據(jù)定義功能_第3頁(yè)
數(shù)據(jù)庫(kù)原理及應(yīng)用第二版第3章 SQL語(yǔ)言基礎(chǔ)及數(shù)據(jù)定義功能_第4頁(yè)
數(shù)據(jù)庫(kù)原理及應(yīng)用第二版第3章 SQL語(yǔ)言基礎(chǔ)及數(shù)據(jù)定義功能_第5頁(yè)
已閱讀5頁(yè),還剩22頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、1第 3 章 SQL語(yǔ)言基礎(chǔ)及數(shù)據(jù)定義功能 3.1 基本概念3.2 SQL的數(shù)據(jù)類型3.3 數(shù)據(jù)定義功能 23.1 基本概念一、SQL語(yǔ)言特點(diǎn) SQL語(yǔ)言集數(shù)據(jù)查詢、數(shù)據(jù)操縱、數(shù)據(jù)定義和數(shù)據(jù)控制功能于一身,其主要特點(diǎn)包括:一體化 高度非過(guò)程化簡(jiǎn)潔以多種方式使用3二、 SQL語(yǔ)言功能概述 SQL按其功能可分為四大部分:數(shù)據(jù)定義功能、數(shù)據(jù)控制功能、數(shù)據(jù)查詢功能和數(shù)據(jù)操縱功能。 Sql功能命令動(dòng)詞數(shù)據(jù)定義CREATE 、DROP 、ALTER數(shù)據(jù)查詢SELECT數(shù)據(jù)操縱INSERT 、UPDATE 、DELETE數(shù)據(jù)控制GRANT 、REVOKE43.2 SQL的數(shù)據(jù)類型數(shù)值型 準(zhǔn)確型:指在計(jì)算機(jī)中

2、能夠精確存儲(chǔ)的數(shù) 據(jù)。近似型:用于表示浮點(diǎn)型數(shù)據(jù)的近似數(shù)據(jù) 類型。 字符串型 字符串?dāng)?shù)據(jù)由漢字、英文字母、數(shù)字和各種符號(hào)組成。貨幣型5日期時(shí)間類型 輸入日期時(shí):Oct 25 2001 /*英文數(shù)字格式*/2001-10-15或2001/10/15 /*數(shù)字加分隔符格式*/20011020 /*純數(shù)字格式*/輸入時(shí)間時(shí):2001-10-15 3:22:45 PM /*12小時(shí)格式*/2001-10-15 15:22:45 /*24小時(shí)格式*/63.3 數(shù)據(jù)定義功能 一、基本表的定義與刪除 1、定義基本表 一般格式為 : CREATE TABLE ( 列級(jí)完整性約束定義 , 列級(jí)完整性約束定義 ,

3、 表級(jí)完整性約束定義 )7其中:所要定義的基本表的名字。:表中所包含的屬性列的名字。指明列的數(shù)據(jù)類型。 在定義表的同時(shí)可以定義與表有關(guān)的完整性約束條件。如果完整性約束只涉及到表中的一個(gè)列,則可以在列級(jí)完整性約束定義處定義,也可以在表級(jí)完整性約束定義處定義;如果完整性約束條件涉及表中多個(gè)屬性列,則必須在表級(jí)完整性約束定義處定義。8在列級(jí)完整性約束定義處可以定義如下約束:NOT NULL:限制列取值非空 DEFAULT:給定列的默認(rèn)值,使用形式為: DEFAULT 常量UNIQUE:限制列取值不重 CHECK:限制列的取值范圍,使用形式為: CHECK(約束表達(dá)式) PRIMARY KEY:指定本

4、列為主碼 FOREIGN KEY:定義本列為引用其他表的外碼。 使用形式為: FOREIGN KEY () REFERENCES () 9但有些約束必須在表級(jí)約束處定義:第一,如果CHECK約束是定義多列之間的取 值約束;第二,如果表的主碼由多個(gè)列組成;第三,如果在表級(jí)完整性約束處定義外碼, 則FOREIGN KEY和均不能省, 且必須用括號(hào)括起來(lái)。即: PRIMARY KEY (列1 ,列2) 10用SQL語(yǔ)句創(chuàng)建Student表列名 說(shuō)明 數(shù)據(jù)類型 約束 Sno 學(xué)號(hào) 字符串,長(zhǎng)度為7 主碼 Sname 姓名 字符串,長(zhǎng)度為10 非空 Ssex 性別 字符串,長(zhǎng)度為2 取男或女 Sage

5、年齡 微整數(shù) 取值1545 Sdept 所在系 字符串,長(zhǎng)度為20 默認(rèn)為計(jì)算機(jī)系Student表結(jié)構(gòu)CREATE TABLE Student ( Sno char ( 7 ) PRIMARY KEY, Sname char ( 10 ) NOT NULL, Ssex char (2) CHECK (Ssex = 男 OR Ssex = 女), Sage tinyint CHECK (Sage = 15 AND Sage =45), Sdept char (20 ) DEFAULT 計(jì)算機(jī)系 )11用SQL語(yǔ)句創(chuàng)建Course表列名 說(shuō)明數(shù)據(jù)類型約束Cno 課程號(hào) 字符串,長(zhǎng)度為10 主碼 C

6、name 課程名 字符串,長(zhǎng)度為20 非空 Ccredit 學(xué)分 微整數(shù) Semster 學(xué)期 微整數(shù) course表結(jié)構(gòu) CREATE TABLE Course ( Cno char(10) NOT NULL, Cname char(20) NOT NULL, Ccredit tinyint , Semester tinyint , PRIMARY KEY(Cno) ) 12用SQL語(yǔ)句創(chuàng)建SC表列名 說(shuō)明 數(shù)據(jù)類型 約束 Sno 學(xué)號(hào) 字符串,長(zhǎng)度為7 主碼,引用Student的外碼 Cno 課程名 字符串,長(zhǎng)度為10 主碼,引用Course的外碼 Grade成績(jī)小整數(shù)XKLB 修課類別字

7、符串,長(zhǎng)度為4sc表結(jié)構(gòu) CREATE TABLE SC ( Sno char(7) NOT NULL, Cno char(10) NOT NULL, Grade smallint, XKLB char(4), PRIMARY KEY ( Sno, Cno ), FOREIGN KEY ( Sno ) REFERENCES Student ( Sno ), FOREIGN KEY ( Cno ) REFERENCES Course ( Cno ) )132、刪除表刪除表的語(yǔ)句格式為: DROP TABLE , 例:刪除test表的語(yǔ)句為: DROP TABLE test14二、修改表結(jié)構(gòu) Se

8、rver的ALTER TABLE語(yǔ)句的部分格式:ALTER TABLE ALTER COLUMN |ADD 屬性|DROP COLUMN |ADD constraint 約束名 約束定義|DROP constraint 約束名 15例1為SC表添加“修課類別”列,此列的定義為:XKLB char(4) ALTER TABLE SC ADD XKLB char(4) NULL例2將新添加的XKLB的類型改為char(6)。 ALTER TABLE SC ALTER COLUMN XKLB char(6)例3刪除Course表的Period列 ALTER TABLE Course DROP COL

9、UMN Period16三、數(shù)據(jù)完整性 數(shù)據(jù)完整性是指數(shù)據(jù)的正確性和相容性。為了防止數(shù)據(jù)庫(kù)中存在不符合語(yǔ)義的數(shù)據(jù),為了維護(hù)數(shù)據(jù)的完整性,數(shù)據(jù)庫(kù)管理系統(tǒng)必須提供一種機(jī)制來(lái)檢查數(shù)據(jù)庫(kù)中的數(shù)據(jù),看其是否滿足語(yǔ)義規(guī)定的條件。這些加在數(shù)據(jù)庫(kù)數(shù)據(jù)之上的語(yǔ)義約束條件就是數(shù)據(jù)完整性約束條件。而DBMS檢查數(shù)據(jù)是否滿足完整性條件的機(jī)制就稱為完整性檢查。 171、完整性約束條件的作用對(duì)象 完整性約束條件的作用對(duì)象可以是表、元組和列。(1)列級(jí)約束對(duì)數(shù)據(jù)類型的約束:包括數(shù)據(jù)類型、長(zhǎng)度、精度等。對(duì)數(shù)據(jù)格式的約束:如規(guī)定學(xué)號(hào)的前兩位表示學(xué)生的入學(xué)年份,第三位表示系的編號(hào),第四位表示專業(yè)編號(hào),第五位代表班的編號(hào)等等。對(duì)取

10、值范圍或取值集合的約束:如學(xué)生的成績(jī)?nèi)≈捣秶鸀?100。對(duì)空值的約束:列是否允許為空。18(2)元組約束 元組的約束是元組中各個(gè)字段之間的聯(lián)系的約束,如:借閱日期 應(yīng)還日期。(3)關(guān)系約束 關(guān)系約束是指若干元組之間、關(guān)系之間的聯(lián)系的約束。比如學(xué)號(hào)的取值不能重復(fù)也不能取空值,學(xué)生修課表中的學(xué)號(hào)的取值受學(xué)生表中的學(xué)號(hào)取值的約束等。192、實(shí)現(xiàn)數(shù)據(jù)完整性 實(shí)現(xiàn)完整性一般是在服務(wù)器端完成的。方法有兩種:一種是在定義表時(shí)聲明數(shù)據(jù)完整性;另一種是在服務(wù)器編寫觸發(fā)器來(lái)實(shí)現(xiàn)。 實(shí)體完整性(PRIMARY KEY) 引用完整性(FOREIGN KEY) 用戶定義的完整性,包括: 默認(rèn)值(DEFAULT)約束 列

11、值取值范圍(CHECK)約束 惟一值約束(UNIQUE)20 以雇員表和工作表為例,在這兩張表上添加約束。這兩張表的結(jié)構(gòu)如下: 雇員表 ( 雇員編號(hào) 字符型 長(zhǎng)度為7 非空, 雇員名 字符型,長(zhǎng)度為10, 工作編號(hào) 字符型,長(zhǎng)度為8, 工資 整型, 電話 字符型,長(zhǎng)度為8 非空) 工作表 ( 工作編號(hào) 字符型,長(zhǎng)度為8,非空, 最低工資 整型, 最高工資 整型 )21 (1)主碼約束 a、每個(gè)表只能有一個(gè); b、用PRIMARY KEY約束的列取值不能有重復(fù),而且不允許有空值; 添加主碼約束的語(yǔ)法格式為: ALTER TABLE 表名 ADD CONSTRAINT 約束名 PRIMARY KE

12、Y ( , n ) 例1:對(duì)雇員表和工作表分別添加主碼約束。 ALTER TABLE 雇員表 ADD CONSTRAINT PK_EMP PRIMARY KEY (雇員編號(hào)) ALTER TABLE 工作表 ADD CONSTRAINT PK_JOB PRIMARY KEY (工作編號(hào))22 (2)UNIQUE約束 用于限制在一個(gè)列中不能有重復(fù)的值。 定義UNIQUE約束時(shí)注意如下事項(xiàng): 允許有一個(gè)空值; 在一個(gè)表中可以定義多個(gè)UNIQUE約束; 可以在一個(gè)列或多個(gè)列上定義UNIQUE約束; 添加UNIQUE約束的語(yǔ)法格式為: ALTER TABLE 表名 ADD CONSTRAINT 約束名

13、 UNIQUE( , n ) 例2為雇員表的“電話”列添加UNIQUE約束。 ALTER TABLE 雇員表 ADD CONSTRAINT UK_SID UNIQUE(電話)23(3)外碼約束 外碼約束實(shí)現(xiàn)了引用完整性。 添加FOREIGN KEY約束的語(yǔ)法格式為: ALTER TABLE 表名 ADD CONSTRAINT 約束名 FOREIGN KEY() REFERENCES 引用表名() 例3為雇員表的工作編號(hào)添加外碼引用約束,此列引用工作表的工作編號(hào)列。 ALTER TABLE 雇員 ADD CONSTRAINT FK_job_id FOREIGN KEY (工作編號(hào)) REFERENCES 工作表 (工作編號(hào)) 24 (4)DEFAULT約束 DEFAULT約束用于提供列的默認(rèn)值。 添加DEFAULT約束的語(yǔ)法格式為: ALTER TABLE 表名 ADD CONSTRAINT 約束名 DEFAULT 默認(rèn)值 FOR 列名 例4定義雇員表的工資的默認(rèn)值為1000。 ALTER TABLE 雇員 ADD CONSTRAINT DF_SALARY DEFAULT 1000 FOR 工資25 (5)CHECK約束 用于限制列的取值在指定的范圍內(nèi)??杉s束同一個(gè)表中多個(gè)列之間的取值關(guān)系。 添加CHECK約束的語(yǔ)法格式為:

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論