信息管理與數(shù)據(jù)庫(kù)技術(shù)3-SQL定義.ppt
《信息管理與數(shù)據(jù)庫(kù)技術(shù)3-SQL定義.ppt》由會(huì)員分享,可在線閱讀,更多相關(guān)《信息管理與數(shù)據(jù)庫(kù)技術(shù)3-SQL定義.ppt(27頁(yè)珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。
關(guān)系數(shù)據(jù)庫(kù)標(biāo)準(zhǔn)語(yǔ)言SQL 主講人 文娟wenjuan 關(guān)系數(shù)據(jù)庫(kù)標(biāo)準(zhǔn)語(yǔ)言SQL SQL概述數(shù)據(jù)定義查詢數(shù)據(jù)更新視圖數(shù)據(jù)控制嵌入式SQL小結(jié) SQL概述 SQL的特點(diǎn)1 綜合統(tǒng)一2 高度非過(guò)程化3 面向集合的操作方式4 以同一種語(yǔ)法結(jié)構(gòu)提供兩種使用方法5 語(yǔ)言簡(jiǎn)潔 易學(xué)易用 5 語(yǔ)言簡(jiǎn)捷 易學(xué)易用 SQL概述數(shù)據(jù)定義查詢數(shù)據(jù)更新視圖數(shù)據(jù)控制嵌入式SQL小結(jié) 數(shù)據(jù)定義 定義語(yǔ)句格式 CREATETABLE 所要定義的基本表的名字 組成該表的各個(gè)屬性 列 涉及相應(yīng)屬性列的完整性約束條件 涉及一個(gè)或多個(gè)屬性列的完整性約束條件 例題 例1 建立一個(gè) 學(xué)生 表Student 它由學(xué)號(hào)Sno 姓名Sname 性別Ssex 年齡Sage 所在系Sdept五個(gè)屬性組成 其中學(xué)號(hào)不能為空 值是唯一的 并且姓名取值也唯一 例題 續(xù) 例題 續(xù) CREATETABLEStudent SnoCHAR 5 NOTNULLUNIQUE SnameCHAR 20 UNIQUE SsexCHAR 1 SageINT SdeptCHAR 15 定義基本表 續(xù) 常用完整性約束主碼約束 PRIMARYKEY唯一性約束 UNIQUE非空值約束 NOTNULL參照完整性約束PRIMARYKEY與UNIQUE的區(qū)別 例題 續(xù) 例2 建立一個(gè) 學(xué)生選課 表SC 它由學(xué)號(hào)Sno 課程號(hào)Cno 修課成績(jī)Grade組成 其中 Sno Cno 為主碼 CREATETABLESC SnoCHAR 5 CnoCHAR 3 Gradeint Primarykey Sno Cno 刪除基本表 DROPTABLE 基本表刪除數(shù)據(jù) 表上的索引都刪除表上的視圖往往仍然保留 但無(wú)法引用刪除基本表時(shí) 系統(tǒng)會(huì)從數(shù)據(jù)字典中刪去有關(guān)該基本表及其索引的描述 標(biāo)準(zhǔn)中沒(méi)有 認(rèn)為表建立后就永久存在 例題 例5 刪除Student表DROPTABLEStudent 修改基本表 ALTERTABLE ADD 完整性約束 DROP MODIFY 要修改的基本表ADD子句 增加新列和新的完整性約束條件DROP子句 刪除指定的完整性約束條件MODIFY子句 用于修改列名和數(shù)據(jù)類型 例題 例2 向Student表增加 入學(xué)時(shí)間 列 其數(shù)據(jù)類型為日期型 ALTERTABLEStudentADDScomeDATE 不論基本表中原來(lái)是否已有數(shù)據(jù) 新增加的列一律為空值 語(yǔ)句格式 續(xù) 刪除屬性列直接 間接刪除把表中要保留的列及其內(nèi)容復(fù)制到一個(gè)新表中刪除原表再將新表重命名為原表名直接刪除屬性列 新 例 ALTERTABLEStudentDropScome 例題 例3 將年齡的數(shù)據(jù)類型改為半字長(zhǎng)整數(shù) ALTERTABLEStudentMODIFYSageSMALLINT 注 修改原有的列定義有可能會(huì)破壞已有數(shù)據(jù) 例題 例4 刪除學(xué)生姓名必須取唯一值的約束 ALTERTABLEStudentDROPUNIQUE Sname 建立與刪除索引 建立索引是加快查詢速度的有效手段建立索引DBA或表的屬主 即建立表的人 根據(jù)需要建立有些DBMS自動(dòng)建立以下列上的索引PRIMARYKEYUNIQUE維護(hù)索引DBMS自動(dòng)完成使用索引DBMS自動(dòng)選擇是否使用索引以及使用哪些索引 建立索引 語(yǔ)句格式CREATE UNIQUE CLUSTER INDEXON 用指定要建索引的基本表名字索引可以建立在該表的一列或多列上 各列名之間用逗號(hào)分隔用指定索引值的排列次序 升序 ASC 降序 DESC 缺省值 ASCUNIQUE表明此索引的每一個(gè)索引值只對(duì)應(yīng)唯一的數(shù)據(jù)記錄CLUSTER表示要建立的索引是聚簇索引 例題 例6 為學(xué)生 課程數(shù)據(jù)庫(kù)中的Student Course SC三個(gè)表建立索引 其中Student表按學(xué)號(hào)升序建唯一索引 Course表按課程號(hào)升序建唯一索引 SC表按學(xué)號(hào)升序和課程號(hào)降序建唯一索引 CREATEUNIQUEINDEXStusnoONStudent Sno CREATEUNIQUEINDEXCoucnoONCourse Cno CREATEUNIQUEINDEXSCnoONSC SnoASC CnoDESC 建立索引 續(xù) 唯一值索引對(duì)于已含重復(fù)值的屬性列不能建UNIQUE索引對(duì)某個(gè)列建立UNIQUE索引后 插入新記錄時(shí)DBMS會(huì)自動(dòng)檢查新記錄在該列上是否取了重復(fù)值 這相當(dāng)于增加了一個(gè)UNIQUE約束 建立索引 續(xù) 聚簇索引建立聚簇索引后 基表中數(shù)據(jù)也需要按指定的聚簇屬性值的升序或降序存放 也即聚簇索引的索引項(xiàng)順序與表中記錄的物理順序一致例 CREATECLUSTERINDEXStusnameONStudent Sname 在Student表的Sname 姓名 列上建立一個(gè)聚簇索引 而且Student表中的記錄將按照Sname值的升序存放 建立索引 續(xù) 在一個(gè)基本表上最多只能建立一個(gè)聚簇索引聚簇索引的用途 對(duì)于某些類型的查詢 可以提高查詢效率聚簇索引的適用范圍很少對(duì)基表進(jìn)行增刪操作很少對(duì)其中的變長(zhǎng)列進(jìn)行修改操作 刪除索引 DROPINDEX 刪除索引時(shí) 系統(tǒng)會(huì)從數(shù)據(jù)字典中刪去有關(guān)該索引的描述 例7 刪除Student表的Stusname索引 DROPINDEXStusname 本節(jié)結(jié)束- 1.請(qǐng)仔細(xì)閱讀文檔,確保文檔完整性,對(duì)于不預(yù)覽、不比對(duì)內(nèi)容而直接下載帶來(lái)的問(wèn)題本站不予受理。
- 2.下載的文檔,不會(huì)出現(xiàn)我們的網(wǎng)址水印。
- 3、該文檔所得收入(下載+內(nèi)容+預(yù)覽)歸上傳者、原創(chuàng)作者;如果您是本文檔原作者,請(qǐng)點(diǎn)此認(rèn)領(lǐng)!既往收益都?xì)w您。
下載文檔到電腦,查找使用更方便
9.9 積分
下載 |
- 配套講稿:
如PPT文件的首頁(yè)顯示word圖標(biāo),表示該P(yáng)PT已包含配套word講稿。雙擊word圖標(biāo)可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國(guó)旗、國(guó)徽等圖片,僅作為作品整體效果示例展示,禁止商用。設(shè)計(jì)者僅對(duì)作品中獨(dú)創(chuàng)性部分享有著作權(quán)。
- 關(guān) 鍵 詞:
- 信息管理 數(shù)據(jù)庫(kù)技術(shù) SQL 定義
鏈接地址:http://www.3dchina-expo.com/p-6252492.html