




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第10章視圖和索引教學(xué)內(nèi)容1、詳細(xì)介紹視圖的基本概念和操作2、詳細(xì)介紹索引的基本概念和操作第10章視圖與索引教學(xué)目的與要求理解視圖的基本概念掌握視圖的基本操作理解索引的基本概念掌握索引的基本操作第10章視圖與索引重點(diǎn)理解視圖的基本概念掌握視圖的創(chuàng)建、修改、使用、刪除基本操作理解索引的基本概念掌握索引的分類、創(chuàng)建、查看、刪除基本操作難點(diǎn)視圖、索引的操作第10章視圖與索引課程引入:視圖索引1視圖——視圖概述視圖概述數(shù)據(jù)庫(kù)的基本表是按照數(shù)據(jù)庫(kù)設(shè)計(jì)人員的觀點(diǎn)設(shè)計(jì)的,并不一定符合用戶的需求。SQLServer2005可以根據(jù)用戶需求重新定義表的數(shù)據(jù)結(jié)構(gòu),這種數(shù)據(jù)結(jié)構(gòu)就是視圖。視圖是關(guān)系數(shù)據(jù)庫(kù)系統(tǒng)提供給用戶以多種角度觀察數(shù)據(jù)庫(kù)中數(shù)據(jù)的重要機(jī)制,其結(jié)構(gòu)和數(shù)據(jù)是建立在對(duì)表的查詢基礎(chǔ)上的。視圖不是真實(shí)存在的基本表而是一張?zhí)摫?,視圖所對(duì)應(yīng)的數(shù)據(jù)并不實(shí)際地以視圖結(jié)構(gòu)存儲(chǔ)在數(shù)據(jù)庫(kù)中,而是存儲(chǔ)在視圖所引用的表中。1視圖——視圖概述視圖優(yōu)點(diǎn)(1)為用戶集中數(shù)據(jù),簡(jiǎn)化用戶的數(shù)據(jù)查詢和處理。(2)保證數(shù)據(jù)的邏輯獨(dú)立性。(3)重新定制數(shù)據(jù),使得數(shù)據(jù)便于共享;合并分割數(shù)據(jù),有利于數(shù)據(jù)輸出到應(yīng)用程序中。(4)數(shù)據(jù)保密。1視圖——?jiǎng)?chuàng)建視圖視圖創(chuàng)建視圖在數(shù)據(jù)庫(kù)中是作為一個(gè)獨(dú)立的對(duì)象存儲(chǔ)的,必須遵循以下原則。①只能在當(dāng)前數(shù)據(jù)庫(kù)中創(chuàng)建視圖。②視圖名稱必須遵循標(biāo)識(shí)符的規(guī)則,且對(duì)每個(gè)用戶必須唯一。此外,該名稱不得與該用戶擁有的任何表的名稱相同。③用戶可以在其他視圖之上建立視圖。④如果視圖中的某一列是一個(gè)算術(shù)表達(dá)式、內(nèi)置函數(shù)或常量派生而來(lái),而且視圖中兩個(gè)或者更多的不同列擁有一個(gè)相同的名字(這種情況通常是因?yàn)樵谝晥D的定義中有一個(gè)連接,而且這兩個(gè)或者多個(gè)來(lái)自不同表的列擁有相同的名字),此時(shí),用戶需要為視圖的每一列指定特定的名稱。⑤定義視圖的查詢不可以包含ORDERBY,COMPUTE或COMPUTEBY子句或INTO關(guān)鍵字。⑥不能在視圖上定義全文索引定義。⑦不能創(chuàng)建臨時(shí)視圖,也不能在臨時(shí)表上創(chuàng)建視圖。⑧不能對(duì)視圖執(zhí)行全文查詢,但是如果查詢所引用的表支持全文索引,就可以在視圖定義中包含全文查詢。⑨不能將規(guī)則或者DEFAULT定義關(guān)聯(lián)于視圖。1視圖——?jiǎng)?chuàng)建視圖1.在SQLServerManagementStudio中創(chuàng)建視圖在SQLServerManagementStudio使用向?qū)?chuàng)建視圖是一種圖形界面環(huán)境下最快捷的創(chuàng)建方式,其步驟如下:(1)在“對(duì)象資源管理器”中展開(kāi)要?jiǎng)?chuàng)建視圖的數(shù)據(jù)庫(kù)如“教學(xué)庫(kù)”,展開(kāi)“視圖”選項(xiàng),可以看到視圖列表中系統(tǒng)自動(dòng)為數(shù)據(jù)庫(kù)創(chuàng)建的系統(tǒng)視圖。右鍵單擊“視圖”選項(xiàng),選擇“新建視圖”菜單,打開(kāi)“添加表”對(duì)話框,在此對(duì)話框中,可以選擇表、視圖或者函數(shù),然后單擊“添加”按鈕,就可以將其添加到視圖查詢中。(2)以創(chuàng)建學(xué)生表中所有男生信息的視圖為例。選擇“學(xué)生”表后,單擊“添加”按鈕,單擊“關(guān)閉”按鈕,返回“新建視圖”對(duì)話框。(3)在對(duì)話框上半部分,可看到添加進(jìn)來(lái)的“學(xué)生”表,選擇視圖所用的列;在對(duì)話框中間網(wǎng)格窗格部分,可看到在上半部分的復(fù)選框中所選擇的對(duì)應(yīng)表的列,在“性別”列的篩選器中寫出篩選條件“=‘男’”;在對(duì)話框下半部分,可看到系統(tǒng)同時(shí)生成的T-SQL語(yǔ)句。然后,單擊工具欄上的“保存”按鈕,視圖取名為“男生視圖”。在“對(duì)象資源管理器”中展開(kāi)創(chuàng)建了視圖的數(shù)據(jù)庫(kù)如“教學(xué)庫(kù)”,展開(kāi)“視圖”選項(xiàng),就可以看到視圖列表中剛創(chuàng)建好的“男生視圖”。如果沒(méi)有看到,單擊“刷新”按鈕,刷新一次即可。1視圖——?jiǎng)?chuàng)建視圖2.使用T-SQL語(yǔ)句創(chuàng)建視圖SQLServer2005提供了CREATEVIEW語(yǔ)句創(chuàng)建視圖,語(yǔ)法格式如下:CREATEVIEW[schema_name.]view_name[(column_name[,...n])][with<view_attribute>[…n]]ASselect_statement[;][WITHCHECKOPTION]1視圖——?jiǎng)?chuàng)建視圖2.使用T-SQL語(yǔ)句創(chuàng)建視圖[例10-1]創(chuàng)建學(xué)生_課程_成績(jī)視圖,包括計(jì)算機(jī)專業(yè)的學(xué)生的學(xué)號(hào)、姓名,和他們選修的課程號(hào)、課程名和成績(jī)。USE教學(xué)庫(kù)GOCREATEVIEW學(xué)生_課程_成績(jī)ASSELECT學(xué)生.學(xué)生號(hào),姓名,課程.課程號(hào),課程名,成績(jī)FROM學(xué)生,選課,課程WHERE學(xué)生.學(xué)生號(hào)=選課.學(xué)生號(hào)AND課程.課程號(hào)=選課.課程號(hào)AND專業(yè)='計(jì)算機(jī)'GO1視圖——?jiǎng)?chuàng)建視圖2.使用T-SQL語(yǔ)句創(chuàng)建視圖[例10-2]創(chuàng)建庫(kù)存統(tǒng)計(jì)視圖,求每種商品的總庫(kù)存數(shù)量,要求包括商品編號(hào)和商品名稱。USE倉(cāng)庫(kù)庫(kù)存GOCREATEVIEW庫(kù)存統(tǒng)計(jì)視圖ASSELECT商品.商品編號(hào),商品名稱,sum(數(shù)量)AS總庫(kù)存數(shù)量FROM商品,庫(kù)存情況WHERE商品.商品編號(hào)=庫(kù)存情況.商品編號(hào)GROUPBY商品.商品編號(hào),商品名稱GO1視圖——修改視圖在SQLServerManagementStudio中修改視圖使用SQLServerManagementStudio修改視圖的操作步驟如下:(1)打開(kāi)SQLServerManagementStudio中的對(duì)象資源管理器,展開(kāi)相應(yīng)數(shù)據(jù)庫(kù)文件夾。(2)展開(kāi)“視圖”選項(xiàng),右擊要修改的視圖,選擇“修改”命令,打開(kāi)的對(duì)話框可用來(lái)修改視圖的定義。(3)如果要向視圖中再添加表,則可以在窗格中右擊鼠標(biāo),選擇“添加表”。同樣,如果要移除表,則右擊要被移除的表,選擇“移除”命令。1視圖——修改視圖在SQLServerManagementStudio中修改視圖(4)如果要修改其他屬性,則在對(duì)話框上半部分,可重新選擇視圖所用的列;在中間的網(wǎng)格窗格部分,對(duì)視圖對(duì)每一列進(jìn)行屬性設(shè)置。最后,單擊工具欄上的“保存”按鈕保存修改后的視圖。(5)例如,修改“男生視圖”,用于查詢所有男生選課情況的信息。首先添加“選課”表,然后選擇其中的“課程號(hào)”和“成績(jī)”列,其它屬性不變,在對(duì)話框下半部分,可看到系統(tǒng)同時(shí)對(duì)T-SQL語(yǔ)句的修改。最后,單擊工具欄上的“保存”按鈕保存修改后的“男生視圖”。1視圖——修改視圖2.使用T-SQL語(yǔ)句修改視圖T-SQL提供了ALTERVIEW語(yǔ)句修改視圖,語(yǔ)法格式如下:ALTERVIEW[schema_name.]view_name[(column_name[,...n])][with<view_attribute>[…n]]ASselect_statement[;][WITHCHECKOPTION]注:語(yǔ)句中的參數(shù)與CREATEVIEW語(yǔ)句中的參數(shù)相同。1視圖——修改視圖2.使用T-SQL語(yǔ)句修改視圖[例10-3]修改庫(kù)存統(tǒng)計(jì)視圖,求每種商品的總庫(kù)存數(shù)量和總價(jià)錢,要求包括商品編號(hào)和商品名稱。USE倉(cāng)庫(kù)庫(kù)存GOALTERVIEW庫(kù)存統(tǒng)計(jì)視圖ASSELECT商品.商品編號(hào),商品名稱,sum(數(shù)量)AS總庫(kù)存數(shù)量,單價(jià)*sum(數(shù)量)AS總價(jià)FROM商品,庫(kù)存情況WHERE商品.商品編號(hào)=庫(kù)存情況.商品編號(hào)GROUPBY商品.商品名稱,商品.商品編號(hào),商品.單價(jià)GO1視圖——使用視圖1.使用視圖進(jìn)行數(shù)據(jù)查詢[例10-4]在查詢窗口中查詢學(xué)生_課程_成績(jī)視圖,統(tǒng)計(jì)“C++語(yǔ)言”課程的總分和平均分。USE教學(xué)庫(kù)GOSELECT總分=SUM(成績(jī)),平均分=AVG(成績(jī))FROM學(xué)生_課程_成績(jī)WHERE課程名='C++語(yǔ)言'GO本例的執(zhí)行結(jié)果為:總分平均分----------------------154771視圖——使用視圖1.使用視圖進(jìn)行數(shù)據(jù)查詢[例10-5]在查詢窗口中查詢“冰箱”的庫(kù)存統(tǒng)計(jì)信息。USE倉(cāng)庫(kù)庫(kù)存GOSELECT*FROM庫(kù)存統(tǒng)計(jì)視圖WHERE商品名稱='冰箱'本例的執(zhí)行結(jié)果為:商品編號(hào)商品名稱總庫(kù)存數(shù)量總價(jià)-----------------------------------------------------bx-179冰箱26400bx-340冰箱125681視圖——使用視圖2.使用視圖修改基本表中數(shù)據(jù)修改視圖的數(shù)據(jù),其實(shí)就是對(duì)基本表進(jìn)行修改,真正插入數(shù)據(jù)的地方是基本表,而不是視圖,同樣使用INSERT、UPDATE、DELETE語(yǔ)句來(lái)完成。但是在對(duì)視圖進(jìn)行修改的時(shí)候也要注意一些事項(xiàng),并不是所有的視圖都可以更新,只有對(duì)滿足以下可更新條件的視圖才能進(jìn)行更新。1視圖——使用視圖2.使用視圖修改基本表中數(shù)據(jù)(1)任何修改(包括UPDATE、INSERT和DELETE語(yǔ)句)都只能引用一個(gè)基本表的列。(2)視圖中被修改的列必須直接引用表列中的基礎(chǔ)數(shù)據(jù)。不能通過(guò)任何其他方式對(duì)這些列進(jìn)行派生,如通過(guò)聚合函數(shù)、計(jì)算(如表達(dá)式計(jì)算)、集合運(yùn)算等。(3)被修改的列不受GROUPBY、HAVING、DISTINCT或TOP子句的影響。1視圖——使用視圖2.使用視圖修改基本表中數(shù)據(jù)即使是可更新視圖,也不能隨意更新數(shù)據(jù)。(1)通常有可能插入并不滿足視圖查詢的WHERE子句條件中的一行。為了進(jìn)行限制此操作,可以在創(chuàng)建視圖時(shí)使用WITHCHECKOPTION選項(xiàng)。(2)如果視圖所依賴的基本表有多個(gè)時(shí),不能向該視圖添加數(shù)據(jù),因?yàn)檫@將影響多個(gè)基本表。(3)修改數(shù)據(jù)時(shí),若視圖依賴于多個(gè)基本表,那么一次修改只能修改一個(gè)基本表中的數(shù)據(jù)。(4)刪除數(shù)據(jù)時(shí),若視圖依賴于多個(gè)基本表,那么不能通過(guò)視圖刪除數(shù)據(jù)。1視圖——使用視圖2.使用視圖修改基本表中數(shù)據(jù)使用視圖修改基本表中數(shù)據(jù)[例10-6]通過(guò)“男生視圖”向“學(xué)生”表中插入一個(gè)“男”生。INSERTINTO男生視圖VALUES('0501001','張三','男','計(jì)算機(jī)')如果通過(guò)“男生視圖”向“學(xué)生”表中插入一個(gè)女生,也可以完成插入,如果不想通過(guò)“男生視圖”插入“女”生,在創(chuàng)建“男生視圖”應(yīng)該使用WITHCHECKOPTIDN選項(xiàng)。1視圖——?jiǎng)h除視圖在不需要該視圖的時(shí)候或想清除視圖定義及與之相關(guān)聯(lián)的權(quán)限時(shí),可以刪除該視圖。視圖的刪除不會(huì)影響所依附的基表的數(shù)據(jù),定義在系統(tǒng)表sysahjects、syscolumns、ments、sysdepends和sysprotects中的視圖信息也會(huì)被刪除。1.在SQLServerManagementStudio刪除視圖在SQLServerManagementStudio中選中要?jiǎng)h除的視圖,右鍵單擊選擇“刪除”命令,進(jìn)入“刪除對(duì)象”窗口,單擊“確定”按鈕就能刪除視圖。1視圖——?jiǎng)h除視圖2.在查詢窗口中執(zhí)行T-SQL語(yǔ)句刪除視圖T-SQL提供了視圖刪除語(yǔ)句DROPVIEW。其語(yǔ)法格式如下:DROPVIEWview_name[例10-7]刪除例10-1創(chuàng)建的學(xué)生_課程_成績(jī)視圖。USE教學(xué)庫(kù)GODROPVIEW學(xué)生_課程_成績(jī)GO
2索引——索引簡(jiǎn)介索引(Index)是對(duì)數(shù)據(jù)庫(kù)表中一個(gè)或多個(gè)列的值進(jìn)行排序的結(jié)構(gòu),其主要目的是提高SQLServer系統(tǒng)的性能,加快數(shù)據(jù)的查詢速度和減少系統(tǒng)的響應(yīng)時(shí)間。所以,索引就是加快檢索表中數(shù)據(jù)的方法。索引簡(jiǎn)介數(shù)據(jù)庫(kù)的索引就類似于書籍的目錄,如果想快速查找而不是逐頁(yè)查找指定的內(nèi)容,可以通過(guò)目錄中章節(jié)的頁(yè)號(hào)找到其對(duì)應(yīng)的內(nèi)容。類似地,索引通過(guò)記錄表中的關(guān)鍵值指向表中的記錄,這樣數(shù)據(jù)庫(kù)引擎就不用掃描整個(gè)表而定位到相關(guān)的記錄。相反,如果沒(méi)有索引,則會(huì)導(dǎo)致SQLServer搜索表中的所有記錄,以獲取匹配結(jié)果。2索引——索引簡(jiǎn)介10.2.1索引簡(jiǎn)介索引的優(yōu)點(diǎn):(1)大大加快數(shù)據(jù)的檢索速度,這是創(chuàng)建索引的最主要的原因。(2)創(chuàng)建唯一性索引,保證表中每一行數(shù)據(jù)的唯一性。(3)加速表和表之間的連接。(4)在使用分組和排序子句進(jìn)行數(shù)據(jù)檢索時(shí),同樣可以顯著減少查詢中分組和排序的時(shí)間。(5)查詢優(yōu)化器可以提高系統(tǒng)的性能,但它是依靠索引起作用的。2索引——索引類型10.2.1索引類型SQLServer2005支持在表中任何列(包括計(jì)算列)上定義索引。索引可以是唯一的,即索引列不會(huì)有兩行記錄相同,這樣的索引稱為唯一索引。例如,如果在表中的“姓名”列上創(chuàng)建了唯一索引,則以后輸入的姓名將不能同名。索引也可以是不唯一的,即索引列上可以有多行記錄相同。如果索引是根據(jù)單列創(chuàng)建的,這樣的索引稱為單列索引,根據(jù)多列組合創(chuàng)建的索引則稱為復(fù)合索引。索引的組織方式的不同,可以將索引分為聚集索引和非聚集索引。2索引——索引類型10.2.1索引類型1.聚集索引聚集索引會(huì)對(duì)表和視圖進(jìn)行物理排序,所以這種索引對(duì)查詢非常有效,在表和視圖中只能有一個(gè)聚集索引。當(dāng)建立主鍵約束時(shí),如果表中沒(méi)有聚集索引,SQLServer會(huì)用主鍵列作為聚集索引鍵。可以在表的任伺列或列的組合上建立索引,實(shí)際應(yīng)用中一般為定義成主鍵約束的列建立聚集索引。例如,漢語(yǔ)字典的正文就是一個(gè)聚集索引的順序結(jié)構(gòu)2索引——索引類型10.2.1索引類型2.非聚集索引非聚集索引不會(huì)對(duì)表和視圖進(jìn)行物理排序。如果表中不存在聚集索引,則表是未排序的。在表或視圖中,最多可以建立250個(gè)非聚集索引,或者249個(gè)非聚集索引和1個(gè)聚集索引。例如,可以根據(jù)“偏旁部首”來(lái)查。比如查“張”字,在查部首之后的檢字表中“張”的頁(yè)碼是622頁(yè),檢字表中“張”的上面是“弛”字,但頁(yè)碼卻是60頁(yè),“張”的下面是“弟”字,頁(yè)碼是95頁(yè),正文中這些字并不是真正的分別位于“張”字的上下方。2索引——索引類型10.2.1索引類型聚集索引和非聚集索引都可以是唯一的索引。因此,只要列中數(shù)據(jù)是唯一的,就可在同一個(gè)表上創(chuàng)建一個(gè)唯一的聚集索引。如果必須實(shí)施唯一性以確保數(shù)據(jù)的完整性,則應(yīng)在列上創(chuàng)建UNIQUE或PRIMARYKEY約束,而不要?jiǎng)?chuàng)建唯一索引。創(chuàng)建PRIMARYKEY或UNIQUE約束會(huì)在表中指定的列上自動(dòng)創(chuàng)建唯一索引。創(chuàng)建UNIQUE約束與手動(dòng)創(chuàng)建唯一索引沒(méi)有明顯的區(qū)別,進(jìn)行數(shù)據(jù)查詢時(shí),查詢方式相同,而且查詢優(yōu)化器不區(qū)分唯一索引是由約束創(chuàng)建還是手動(dòng)創(chuàng)建的。如果存在重復(fù)的鍵值,則無(wú)法創(chuàng)建唯一索引和PRIMARYKEY或UNIQUE約束。如果是復(fù)合的唯一索引,則該索引可以確保索引列中每個(gè)組合都是唯一的,創(chuàng)建復(fù)合唯一索引可為查詢優(yōu)化器提供附加信息,所以對(duì)多列創(chuàng)建復(fù)合索引時(shí)最好是唯一索引。2索引——?jiǎng)?chuàng)建索引我們已經(jīng)知道,創(chuàng)建索引雖然可以提高查詢速度,但是它需要犧牲一定的系統(tǒng)性能。因此,在創(chuàng)建時(shí),哪些列適合創(chuàng)建索引,哪些列不適合創(chuàng)建索引,需要進(jìn)行詳細(xì)的考察。1.創(chuàng)建索引時(shí)應(yīng)考慮的問(wèn)題(1)對(duì)一個(gè)表中建大量的索引,應(yīng)進(jìn)行權(quán)衡。(2)對(duì)于小型表(行數(shù)較少)進(jìn)行索引可能不會(huì)產(chǎn)生優(yōu)化效果。(3)對(duì)于主鍵和外鍵列應(yīng)考慮建索引,因?yàn)榻?jīng)常通過(guò)主鍵查詢數(shù)據(jù),而外鍵用于表間的連接。(4)很少在查詢中使用的列以及值很少的列不應(yīng)考慮建索引。(5)視圖中如果包含聚集函數(shù)或連接時(shí),創(chuàng)建視圖的索引可以顯著提升查詢性能。2索引——?jiǎng)?chuàng)建索引通過(guò)SQLServerManagementStudio創(chuàng)建索引在SQLServerManagementStudio中使用向?qū)?chuàng)建索引是一種圖形界面環(huán)境下最快捷的創(chuàng)建方式,其步驟如下:1)在SQLServerManagementStudio的“對(duì)象資源管理器”面板中,選擇要?jiǎng)?chuàng)建索引的表(如教學(xué)庫(kù)中的學(xué)生表),然后展開(kāi)學(xué)生表前面的“>”號(hào),選中“索引”選頂右擊,在彈出的快捷菜單中選擇“新建索引”命令,如圖所示:。2索引——?jiǎng)?chuàng)建索引通過(guò)SQLServerManagementStudio創(chuàng)建索引(2)選擇“新建索引”命令,進(jìn)入如圖所示的“新建索引”窗口。(3)在“常規(guī)”選項(xiàng)窗口中,可以創(chuàng)建索引,在“索引名稱”文本框中輸入索引名稱,在“索引類型”下拉列表中選擇是不是聚集索引,在“唯一索引”單選框中選擇是否設(shè)置唯一索引等。例如,輸入索引名稱為“index_姓名”,選擇“非聚集”選項(xiàng)。(4)通過(guò)選擇索引設(shè)置按鈕,可以為新建的索引添加、刪除、移動(dòng)索引列。例如,選擇“添加”按鈕,進(jìn)入如圖所示的“添加索引列”窗口,選中“姓名”列前的多選按鈕,單擊“確定”按鈕即可添加一個(gè)按“姓名”列升序排序的非聚集索引。再選擇“確定”按鈕,索引創(chuàng)建完成。(5)索引創(chuàng)建完成后,在SQLServerManagementStudio的“對(duì)象資源管理器”面板中,選擇創(chuàng)建了索引的表(學(xué)生表),展開(kāi)學(xué)生表前面的“>”號(hào),再展開(kāi)“索引”選頂前面的“>”號(hào),就會(huì)出現(xiàn)新建的索引——index_姓名,如圖所示。2索引——?jiǎng)?chuàng)建索引3.利用T-SQL語(yǔ)句創(chuàng)建索引使用T-SQL語(yǔ)句創(chuàng)建索引的語(yǔ)法格式如下:CREATE[UNIQUE][CLUSTERED|NONCLUSTERED]INDEXindex_name
ON{table_name|view_name}(column[ASC|DESC][,...n])[WITH<index_option>[,...n]] [ONfilegroup]
<index_option>::=
{PAD_INDEX|
FILLFACTOR=fillfactor|
IGNORE_DUP_KEY|
DROP_EXISTING|
STATISTICS_NORECOMPUTE}2索引——?jiǎng)?chuàng)建索引3.利用T-SQL語(yǔ)句創(chuàng)建索引[例10-8]根據(jù)教學(xué)庫(kù)中學(xué)生表的姓名列的升序創(chuàng)建一個(gè)名為index_學(xué)生姓名的普通索引。
USE教學(xué)庫(kù)GOCREATEINDEXindex_學(xué)生姓名ON學(xué)生(姓名)GO[例10-9]根據(jù)倉(cāng)庫(kù)庫(kù)存數(shù)據(jù)庫(kù)中商品表的商品名稱、生產(chǎn)商創(chuàng)建一個(gè)名為商品_生產(chǎn)商的唯一性復(fù)合索引,其中商品名稱為升序,生產(chǎn)商為降序。USE倉(cāng)庫(kù)庫(kù)存GOCREATEUNIQUEINDEX商品_生產(chǎn)商ON商品(商品名稱ASC,生產(chǎn)商DESC)GO2索引——?jiǎng)?chuàng)建索引4.間接創(chuàng)建索引在定義表結(jié)構(gòu)或修改表結(jié)構(gòu)時(shí),如果定義了主鍵約束(PRAMARYKEY)或者唯一性約束(UNIQUE),可以間接創(chuàng)建索引。[例10-10]創(chuàng)建一個(gè)學(xué)生1表,并定義了主鍵約束。USE教學(xué)庫(kù)GOCREATETABLE學(xué)生1(snochar(6)PRIMARYKEY,snamechar(8))此例中,就按sno升序創(chuàng)建了一個(gè)聚集索引。2索引——?jiǎng)?chuàng)建索引[例10-11]創(chuàng)建一個(gè)教師表,并定義了主鍵約束和唯一性約束。USE教學(xué)庫(kù)GOCREATETABLE教師(tnochar(6)PRIMARYKEY,tamechar(8)UNIQUE)此n例中,創(chuàng)建了兩個(gè)索引,按tno升序創(chuàng)建了一個(gè)聚集索引,按tname升序創(chuàng)建了一個(gè)非聚集唯一索引。2索引——?jiǎng)?chuàng)建索引5.創(chuàng)建索引視圖視圖也稱為虛擬表,這是因?yàn)橛梢晥D返回的結(jié)果集其一般格式與由列和行組成的表相似,并且,在SQL語(yǔ)句中引用視圖的方式也與引用表的方式相同。標(biāo)準(zhǔn)視圖的結(jié)果集不是永久地存儲(chǔ)在數(shù)據(jù)庫(kù)中。對(duì)于標(biāo)準(zhǔn)視圖而言,為每個(gè)引用視圖的查詢動(dòng)態(tài)生成結(jié)果集的開(kāi)銷很大,特別是對(duì)于那些涉及對(duì)大量行進(jìn)行復(fù)雜處理(如聚合大量數(shù)據(jù)或連接許多行)的視圖更為可觀。若經(jīng)常在查詢中引用這類視圖,可通過(guò)在視圖上創(chuàng)建唯一聚集索引來(lái)提高性能。在視圖上創(chuàng)建唯一聚集索引時(shí)將執(zhí)行該視圖,并且結(jié)果集在數(shù)據(jù)庫(kù)中的存儲(chǔ)方式與帶聚集索引的表的存儲(chǔ)方式相同。2索引——?jiǎng)?chuàng)建索引5.創(chuàng)建索引視圖
可以在SQLServerManagementStudio的對(duì)象資源管理器,展開(kāi)相應(yīng)數(shù)據(jù)庫(kù)文件夾,展開(kāi)“視圖”選項(xiàng),再展開(kāi)要?jiǎng)?chuàng)建索引的視圖,右擊“索引”選項(xiàng)選擇“新建索引”命令。例如,按成績(jī)的升序?yàn)閷W(xué)生_課程_成績(jī)視圖創(chuàng)建一個(gè)唯一的聚集索引,在“新建索引”對(duì)話框內(nèi)輸入索引名,設(shè)置索引類型,單擊“確定”按鈕即可新建一個(gè)索引視圖。2索引——?jiǎng)?chuàng)建索引5.創(chuàng)建索引視圖
[例10-12]創(chuàng)建一個(gè)女學(xué)生的視圖,并為該視圖按學(xué)生號(hào)升序創(chuàng)建一個(gè)具有唯一性的聚集索引。創(chuàng)建視圖:CREATEVIEW女學(xué)生WITHSCHEMABINDINGASSELECT學(xué)生號(hào),姓名,性別,專業(yè)FROMdbo.學(xué)生WHERE性別='女'GO創(chuàng)建索引:CREATEUNIQUECLUSTEREDINDEX女學(xué)生索引ON女學(xué)生(學(xué)生號(hào))GO2索引——查看索引信息查看索引信息在實(shí)際使用索引的過(guò)程中,有時(shí)需要對(duì)表的索引信息進(jìn)行查詢,了解在表中曾經(jīng)建立的索引??梢允褂肧QLServerManagementStudio進(jìn)行查詢;也可以在查詢分析器中使用T-SQL語(yǔ)言進(jìn)行查詢。1.在SQLServerManagementSt
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 標(biāo)準(zhǔn)化住宅小區(qū)業(yè)主物業(yè)服務(wù)合同樣本
- 長(zhǎng)途載重貨車租借合同書
- 建設(shè)工程施工合同風(fēng)險(xiǎn)防范
- 預(yù)售樓盤標(biāo)準(zhǔn)合同文本示例
- 辦公用房租賃合同:商務(wù)合作新篇章
- 標(biāo)準(zhǔn)公寓租賃合同范本
- 租賃酒店場(chǎng)地合同樣本
- 工程項(xiàng)目承包合同公示
- 廣?;▓@A19棟5號(hào)商業(yè)合同簽約注意事項(xiàng)
- 鋼材供應(yīng)合同樣本
- 云計(jì)算服務(wù)應(yīng)用理解試題及答案
- 2025年江蘇省南通市海安市十三校中考一模數(shù)學(xué)試題(原卷版+解析版)
- 浙江2025年桐鄉(xiāng)市事業(yè)單位招考高頻重點(diǎn)模擬試卷提升(共500題附帶答案詳解)
- 2025至2031年中國(guó)管道直飲水系統(tǒng)行業(yè)投資前景及策略咨詢研究報(bào)告
- 2024年可行性研究報(bào)告投資估算及財(cái)務(wù)分析全套計(jì)算表格(含附表-帶只更改標(biāo)紅部分-操作簡(jiǎn)單)
- 國(guó)家開(kāi)放大學(xué)《初級(jí)經(jīng)濟(jì)學(xué)》形考任務(wù)1-3參考答案
- 病原微生物實(shí)驗(yàn)室生物安全備案專家意見(jiàn)表
- (精心整理)朱德熙_說(shuō) “的”
- 《雷鋒叔叔,你在哪里》說(shuō)課稿(附優(yōu)質(zhì)教案)
- 廠用電受電后代保管協(xié)議
- 醫(yī)院住院病歷質(zhì)量檢查評(píng)分表
評(píng)論
0/150
提交評(píng)論