




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第4章
SQL語言基礎及數據定義功能
4.1基本概念4.2SQL的數據類型4.3數據定義功能4.4數據完整性4.1基本概念4.1.2SQL語言特點
SQL語言集數據查詢、數據操縱、數據定義和數據控制功能于一身,其主要特點包括:一體化高度非過程化簡潔以多種方式使用4.1.3SQL語言功能概述
SQL按其功能可分為四大部分:數據定義功能、數據控制功能、數據查詢功能和數據操縱功能。
Sql功能命令動詞數據定義CREATE、DROP、ALTER數據查詢SELECT數據操縱INSERT、UPDATE、DELETE數據控制GRANT、REVOKE4.2SQL的數據類型4.2.1數值型
1.準確型:指在計算機中能夠精確存儲的數據。2.近似型:用于表示浮點型數據的近似數據類型。1)整數型此種數據類型用于存儲整數,沒有小數位。它包括bigint、int、smallint和tinyint4種。其中bigint長度為8個字節。Int長度為4個字節。Smallint長度為2個字節Tinying長度為1個字節,只能存儲0-255范圍內的數字。2)小數數據類型Decimal,精確數據類型,由兩部分構成,一個整數,二是小數部分。Decimal(長度,小數位)3)近似數值型Float型和real數據類型,非精確數據。4.2.2字符串型字符串數據由漢字、英文字母、數字和各種符號組成。字符串存儲時采用字符型數據類型,由字母、符號和數字組成,用引號括起來。主要的數據類型有char、varchar、nvarchar、nchar和text以及ntext類型。Char或text型是固定長度且非unicode的字符。Varchar是一種可變長度且非unicode的字符。Nchar是一種固定的且unicode字符。4.2.3日期時間類型
專門的日期時間類型,格式為月/日/年時:分:秒。有兩種:Datetime和smalldatetime兩種。Datetime能表示:占用8個字節空間,1753年至9999年。Smalldatetime能表示:占用4個字節空間,1900年到2079年。輸入日期時:Oct252001/*英文數字格式*/2001-10-15或2001/10/15/*數字加分隔符格式*/20011020/*純數字格式*/輸入時間時:2001-10-153:22:45PM/*12小時格式*/2001-10-1515:22:45/*24小時格式*/4.3數據定義功能
4.3.1基本表的定義與刪除
1、定義基本表一般格式為:CREATETABLE<表名>(<列名><數據類型>[列級完整性約束定義]{,<列名><數據類型>[列級完整性約束定義]…}
[,表級完整性約束定義])其中:<表名>:所要定義的基本表的名字。<列名>:表中所包含的屬性列的名字。<數據類型>指明列的數據類型。在定義表的同時可以定義與表有關的完整性約束條件。如果完整性約束只涉及到表中的一個列,則可以在列級完整性約束定義處定義,也可以在表級完整性約束定義處定義;如果完整性約束條件涉及表中多個屬性列,則必須在表級完整性約束定義處定義。在列級完整性約束定義處可以定義如下約束:NOTNULL:限制列取值非空DEFAULT:給定列的默認值,使用形式為:
DEFAULT常量UNIQUE:限制列取值不重CHECK:限制列的取值范圍,使用形式為:
CHECK(約束表達式)
PRIMARYKEY:指定本列為主碼FOREIGNKEY:定義本列為引用其他表的外碼。使用形式為:[FOREIGNKEY(<列名>)]REFERENCES<外表名>(<外表列名>)
但有些約束必須在表級約束處定義:第一,如果CHECK約束是定義多列之間的取值約束;第二,如果表的主碼由多個列組成;第三,如果在表級完整性約束處定義外碼,則FOREIGNKEY和<列名>均不能省,且<列名>必須用括號括起來。即:
PRIMARYKEY(列1{[,列2]…})用SQL語句創建Student表列名說明數據類型約束Sno學號字符串,長度為7主碼Sname姓名字符串,長度為10非空Ssex性別字符串,長度為2取‘男’或‘女’Sage年齡微整數取值15~45Sdept所在系字符串,長度為20默認為‘計算機系’表4-6Student表結構CREATETABLEStudent(Snochar(7)PRIMARYKEY,Snamechar(10)NOTNULL,Ssexchar(2)CHECK(Ssex='男'ORSsex='女'),
SagetinyintCHECK(Sage>=15ANDSage<=45),Sdeptchar(20)DEFAULT'計算機系')用SQL語句創建Course表列名說明數據類型約束Cno課程號字符串,長度為10主碼Cname課程名字符串,長度為20非空Ccredit學分微整數Semster學期微整數表4-7course表結構
CREATETABLECourse(Cnochar(10)NOTNULL,Cnamechar(20)NOTNULL,Ccredittinyint,Semestertinyint,
PRIMARYKEY(Cno))
用SQL語句創建SC表列名說明數據類型約束Sno學號字符串,長度為7主碼,引用Student的外碼Cno課程名字符串,長度為10主碼,引用Course的外碼Grade成績小整數XKLB修課類別字符串,長度為4表4-8sc表結構CREATETABLESC(Snochar(7)NOTNULL,Cnochar(10)NOTNULL,Gradesmallyint,XKLBchar(4),
PRIMARYKEY(Sno,Cno),FOREIGNKEY(Sno)REFERENCESStudent(Sno),FOREIGNKEY(Cno)REFERENCESCourse(Cno))2、刪除表刪除表的語句格式為:
DROPTABLE<表名>{[,<表名>]…}
例:刪除test表的語句為:
DROPTABLEtest4.3.2修改表結構
Server的ALTERTABLE語句的部分格式:ALTERTABLE<表名>
[ALTERCOLUMN<列名><新數據類型>]|[ADD<列名><數據類型>[屬性]|[DROPCOLUMN<列名>]|[ADDconstraint約束名約束定義]|[DROPconstraint約束名]例1.為SC表添加“修課類別”列,此列的定義為:XKLBchar(4)
ALTERTABLESCADDXKLBchar(4)NULL例2.將新添加的XKLB的類型改為char(6)。
ALTERTABLESCALTERCOLUMNXKLBchar(6)例3.刪除Course表的Period列ALTERTABLECourseDROPCOLUMNPeriod4.4數據完整性數據完整性是指數據的正確性和相容性。為了防止數據庫中存在不符合語義的數據,為了維護數據的完整性,數據庫管理系統必須提供一種機制來檢查數據庫中的數據,看其是否滿足語義規定的條件。這些加在數據庫數據之上的語義約束條件就是數據完整性約束條件。而DBMS檢查數據是否滿足完整性條件的機制就稱為完整性檢查。4.4.1完整性約束條件的作用對象
完整性約束條件的作用對象可以是表、元組和列。(1)列級約束對數據類型的約束:包括數據類型、長度、精度等。對數據格式的約束:如規定學號的前兩位表示學生的入學年份,第三位表示系的編號,第四位表示專業編號,第五位代表班的編號等等。對取值范圍或取值集合的約束:如學生的成績取值范圍為0~100。對空值的約束:列是否允許為空。(2)元組約束
元組的約束是元組中各個字段之間的聯系的約束,如:借閱日期<應還日期。(3)關系約束
關系約束是指若干元組之間、關系之間的聯系的約束。比如學號的取值不能重復也不能取空值,學生修課表中的學號的取值受學生表中的學號取值的約束等。4.4.2實現數據完整性
實現完整性一般是在服務器端完成的。方法有兩種:一種是在定義表時聲明數據完整性;另一種是在服務器編寫觸發器來實現。實體完整性(PRIMARYKEY)引用完整性(FOREIGNKEY)用戶定義的完整性,包括:默認值(DEFAULT)約束列值取值范圍(CHECK)約束惟一值約束(UNIQUE)以雇員表和工作表為例,在這兩張表上添加約束。這兩張表的結構如下:
雇員表
(雇員編號字符型長度為7非空,雇員名字符型,長度為10,工作編號字符型,長度為8, 工資整型,電話字符型,長度為8非空)
工作表
(工作編號字符型,長度為8,非空,最低工資整型,最高工資整型)
(1)主碼約束
a、每個表只能有一個;b、用PRIMARYKEY約束的列取值不能有重復,而且不允許有空值;添加主碼約束的語法格式為:
ALTERTABLE表名 ADD[CONSTRAINT]約束名PRIMARYKEY(<列名>[,…n])
例1:對雇員表和工作表分別添加主碼約束。
ALTERTABLE雇員表ADDCONSTRAINTPK_EMP
PRIMARYKEY(雇員編號)ALTERTABLE工作表ADDCONSTRAINTPK_JOB
PRIMARYKEY(工作編號)(2)UNIQUE約束
用于限制在一個列中不能有重復的值。定義UNIQUE約束時注意如下事項:允許有一個空值;在一個表中可以定義多個UNIQUE約束;可以在一個列或多個列上定義UNIQUE約束;
添加UNIQUE約束的語法格式為:
ALTERTABLE表名ADD[CONSTRAINT約束名]UNIQUE(<列名>[,…n])
例2.為雇員表的“電話”列添加UNIQUE約束。
ALTERTABLE雇員表
ADDCONSTRAINTUK_SIDUNIQUE(電話)(3)外碼約束
外碼約束實現了引用完整性。添加FOREIGNKEY約束的語法格式為:ALTERTABLE表名ADD[CONSTRAINT約束名]FOREIGNKEY(<列名>)REFERENCES引用表名(<列名>)
例3.為雇員表的工作編號添加外碼引用約束,此列引用工作表的工作編號列。ALTERTABLE雇員ADDCONSTRAINTFK_job_id
FOREIGNKEY(工作編號)
REFERENCES工作表(工作編號)
(4)DE
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 災害救援護理人力資源應急方案流程
- 2025-2030中國家庭醫生行業市場發展分析及前景趨勢與投資研究報告
- 民間借貸中以房抵債合同的法律問題研究
- 語文教師心理健康提升計劃
- 公共設施測繪項目的質量保證與管理措施
- 金融科技對城市商業銀行信用風險的影響研究
- 企業員工技術培訓計劃
- 二十年后回故鄉1000字(7篇)
- 《浮力原理與計算:初中物理必修教案》
- 科學教學計劃:培養孩子的探究精神
- -AAR工具的介紹課件
- 光滑極限量規設計
- 韓國留學詳細介紹課件
- (完整word版)項目進度控制流程圖
- 液化氣站2022年應急預案演練計劃
- 電纜井工程及電纜鋼管敷設施工方案
- 窄線寬光纖激光器研究俞本立
- 我的家鄉湄潭課件
- 人教版六年級下冊數學第五、六單元測試題及答案
- 試模自校規程
- 組織人事業務知識測試二
評論
0/150
提交評論