4、 查詢語句的擴展:
(1) 合并多個結(jié)果集:SELECT 語句1 UNION SELECT 語句2……,使用UNION的兩個基本規(guī)則:
(A) 所有查詢語句中列的個數(shù)和列的順序必須相同;
(B) 所有查詢語句中對應的數(shù)據(jù)類型必須兼容;
(2) 將查詢結(jié)果保存到新表中:SELECT 查詢列表序列 INTO 新表名 FROM 數(shù)據(jù)源;
(3) 使用TOP限制結(jié)果集行數(shù):TOP n [percent] [WITH TIES]
(A) TOP n :表示取查詢結(jié)果的前n行;
(B) TOP n percent:表示取查詢結(jié)果的前n%行;
(C) WITH TIES:表示包括并列的結(jié)果;
(4) 使用CASE表達式:
(A) 簡單CASE表達式:
(B) 搜索CASE表達式;
5、子查詢:如果一個SELECT語句是嵌套在一個SELECT、INSERT、UPDATE或DELETE語句中,則稱為子查詢或內(nèi)層查詢,包含子查詢的語句稱為主查詢或外層查詢;
(1) 使用子查詢進行基于集合的測試,形式:WHERE 表達式 [NOT] IN (子查詢);
(2) 使用子查詢進行比較測試,形式:WHERE 表達式 比較運算符 (子查詢);
(3) 使用子查詢進行存在性測試,形式:WHERE [NOT] EXISTS (子查詢);
8.3.2 數(shù)據(jù)修改
1、 添加數(shù)據(jù):INSERT [INTO] 表名 VALUE 值列表;使用插入單行語句時要注意:
(1) 值列表中的值與列名表中的列按位置順序?qū)笏鼈兊臄?shù)據(jù)類型必須一致;
(2) 如果[表名]后邊沒有指明列名,則值列表中的值的順序必須與表中列的順序一致,且每一列均有值;
2、 更新數(shù)據(jù):形式 UPDATE 表名 SET [列名=表達式] [WHERE 更新條件];
3、 刪除數(shù)據(jù)::形式DELETE [FROM] 表名 [WHERE 刪除條件];
8.4 索引
1、 創(chuàng)建索引:CREATE [UNIQUE] [CLUSTERED | NONCLUSTERED]
INDEX 索引名 ON 表名
(1) UNIQUE:表示要創(chuàng)建的索引是唯一索引;
(2) CLUSTERED:表示要創(chuàng)建的索引是聚集索引;
(3) NONCLUSTERED:表示要創(chuàng)建的索引是非聚集索引;
2、 刪除索引:DROP INDEX 索引名;
8.5 視圖
8.5.1 定義視圖
1、 語法格式:CREATE VIEW 視圖名 AS SELECT 語句 [WITH CHECK OPTION]
2、 需要注意下列幾點:
(1) 在定義視圖時要么指定全部視圖列,要么全部省略不寫。如果省略了視圖列名,則視圖的列名與查詢語句的列名相同。但如下情況則要明確指出組成視圖的所有列名:
A、 某個目標列不是單純的屬性名,而是計算函數(shù)或列的表達式;
B、 多表連接時選出了幾個同名列作為視圖的字段;
C、 需要在視圖中為某個列選用新的更合適的列名。
(2) WITH CHECK OPTION選項表示通過視圖對數(shù)據(jù)進行增加、刪除和更改操作時要保證對數(shù)據(jù)的操作結(jié)果要滿足定義視圖時指定的WHERE子句條件;
3、 視圖通常用于查詢數(shù)據(jù),也可修改基本表中的數(shù)據(jù),但不是所有的視力都可以這樣。
4、 定義單源表視圖—視圖數(shù)據(jù)可只取自一個基本表的部分行、列,這樣的視圖行列與基本表行列對應,這樣定義的視圖一般可以進行查詢和更改數(shù)據(jù)操作
5、 定義多源表視圖—視圖數(shù)據(jù)可以來自多個表中,這樣定義的視圖一般只用于查詢,不用于修改數(shù)據(jù)。
6、 在已有視圖上定義新視圖—可以在視圖上再建立視圖,這時作為數(shù)據(jù)源的視圖必須是已經(jīng)建立好的。
7、 定義帶表達式的視圖—在定義基本表時,為減少數(shù)據(jù)庫中的冗余數(shù)據(jù),表中只存放基本數(shù)據(jù),由基本數(shù)據(jù)經(jīng)過各種計算派生出的數(shù)據(jù)一般是不存儲的。所以定義視圖時可以根據(jù)需要設置一些派生屬性列,在這些派生屬性列中保存經(jīng)過計算的值。這些派生屬性由于在基本表中并不實際存在,因此,也稱它們?yōu)樘摂M列。包含虛擬列的視圖也稱為帶表達式的視圖。
8、 含分組統(tǒng)計信息的視圖—指定義視圖的查詢語句中含有GROUP BY 子句,這樣的視圖只能用于查詢,不能修改數(shù)據(jù)。
8.5.2 刪除視圖
1、 格式為:DROP VIEW <視圖名>
8.5.3 視圖的作用
1、 簡化數(shù)據(jù)查詢語句;
2、 使用戶能從多角度看到同一數(shù)據(jù);
3、 提高了數(shù)據(jù)的安全性;
4、 提供了一定程度的邏輯獨立性
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |