MS SQL Server 2000視圖與其好處描述
以下的文章主要描述的是正確了解MS SQL Server 2000視圖功能與應(yīng)用,在實(shí)際操作中視圖有很多的好處,其中包括橫縱分割表,執(zhí)行和在表上一至的實(shí)際操作,如:Insert、Update、Delete。
這些操作與在表上的相應(yīng)操作大至相同,不過(guò)也有些不同之處。在視圖上進(jìn)行操作的列是只屬于視圖的列,這些列不一定包含對(duì)應(yīng)表中的所有列,所以在執(zhí)行Insert操作或Update操作時(shí),如果視圖中有未被包含的列,并且這些列是Not NULL的,那么在視圖上執(zhí)行相應(yīng)的Insert操作或Update操作時(shí)就會(huì)失敗,還有在MS SQL Server 2000視圖上如果使用了Group By、Distinct等操作時(shí),不能執(zhí)行Insert或Update操作。
還有一點(diǎn)需要注意的是,如果MS SQL Server 2000視圖中包含的不只是一個(gè)表,那么執(zhí)行Insert或Update一次只能對(duì)MS SQL Server 2000視圖中的某個(gè)表進(jìn)行操作,也就是說(shuō),如果視圖中包含了兩個(gè)表A、B,那么就需要對(duì)視圖執(zhí)行兩次Insert或Update操作,一次操作表A的各個(gè)列,一次操作表B的各個(gè)列。
語(yǔ)法:
- Create View View_Name [columnname,……]
- AS Select Statement [WITH CHECK OPTION] [WITH ENCRYPTION]
舉例說(shuō)明:
Use SomeDataBase Go –這句與MySQL的一樣,就是表示要進(jìn)入某個(gè)數(shù)據(jù)庫(kù)
Create View SomeView –創(chuàng)建一個(gè)視圖SomeView
- As
- Select * from UserInfo [WITH ENCRYPTION]
–在Select 語(yǔ)句后加上With Encryption 表示對(duì)MS SQL Server 2000視圖進(jìn)行加密,這樣其它用戶查看這個(gè)視圖時(shí),就看不到視圖中的內(nèi)容。
- GO
事務(wù):
在MS SQL Server中對(duì)事務(wù)的操作一共有四個(gè),它們是:
- Begin Transaction、Commit、Rollback和Save Transaction。
索引:
索引有四種,***索引、簇索引、非簇索引和復(fù)合索引。
表掃描一般用在大表返回絕大多數(shù)數(shù)據(jù)或小表查詢某些數(shù)據(jù)時(shí)使用。在大表中查詢有限量數(shù)據(jù),一般使用索引。
索引其實(shí)是一種與表中的列相綁定的對(duì)象。
使用索引的時(shí)機(jī):
1.經(jīng)常被查詢搜索的列。
2.在Order by子句中使用的列。
3.是外鍵或主鍵的列。
4.該列的值***的列。
不能使用或不適合使用索引的情況:
1.在查詢中很少被引用的列。
2.數(shù)據(jù)類型為bit、text和Image等的列不能建立索引。
語(yǔ)法:
- Create [UNIQUE][CLUSTERED|NONCLUSTERED] Index index_name
- On TableName (Column [,…n])
舉例說(shuō)明:
- Create UNIQUE CLUSTERED Index SomeIndex On UserInfo (UserName)
這就是在表UserInfo的列UserName上建立的一個(gè)***簇集索引。
以上的相關(guān)內(nèi)容就是對(duì)MS SQL Server 2000視圖的介紹,望你能有所收獲。
【編輯推薦】