SQL 使用視圖

2022-05-20 16:35 更新

SQL 使用視圖


 視圖無非就是存儲(chǔ)在數(shù)據(jù)庫中并具有名字的 SQL 語句,或者說是以預(yù)定義的 SQL 查詢的形式存在的數(shù)據(jù)表的成分。

 視圖可以包含表中的所有列,或者僅包含選定的列。視圖可以創(chuàng)建自一個(gè)或者多個(gè)表,這取決于創(chuàng)建該視圖的 SQL 語句的寫法。

 視圖,一種虛擬的表,允許用戶執(zhí)行以下操作:

  • 以用戶或者某些類型的用戶感覺自然或者直觀的方式來組織數(shù)據(jù);
  • 限制對數(shù)據(jù)的訪問,從而使得用戶僅能夠看到或者修改(某些情況下)他們需要的數(shù)據(jù);
  • 從多個(gè)表中匯總數(shù)據(jù),以產(chǎn)生報(bào)表。

創(chuàng)建視圖


 在 SQL 中,視圖是基于 SQL 語句的結(jié)果集的可視化表。

 數(shù)據(jù)庫視圖由 CREATE VIEW 語句創(chuàng)建。視圖可以創(chuàng)建自單個(gè)表、多個(gè)表或者其他視圖。

 視圖中的字段是一個(gè)或多個(gè)數(shù)據(jù)庫中真實(shí)表中的字段。

 在使用時(shí)視圖可以被視為一個(gè)“虛擬表”。    

 要?jiǎng)?chuàng)建視圖的話,用戶必須有適當(dāng)?shù)南到y(tǒng)權(quán)限。具體需要何種權(quán)限隨數(shù)據(jù)庫系統(tǒng)實(shí)現(xiàn)的不同而不同。

 CREATE VIEW 語句的基本語法如下所示:

CREATE VIEW view_name AS
SELECT column1, column2.....
FROM table_name
WHERE [condition];

 和普通的 SQL SELECT 查詢一樣,你可以在上面的 SELECT 語句中包含多個(gè)數(shù)據(jù)表。

注釋:視圖總是顯示最新數(shù)據(jù)!每當(dāng)用戶查詢視圖時(shí),數(shù)據(jù)庫引擎就使用視圖的 SQL 語句重新構(gòu)建數(shù)據(jù)。


SQL CREATE VIEW 示例


示例一

 考慮 CUSTOMERS 表,表中的記錄如下所示:

+----+----------+-----+-----------+----------+
| ID | NAME     | AGE | ADDRESS   | SALARY   |
+----+----------+-----+-----------+----------+
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 |
|  2 | Khilan   |  25 | Delhi     |  1500.00 |
|  3 | kaushik  |  23 | Kota      |  2000.00 |
|  4 | Chaitali |  25 | Mumbai    |  6500.00 |
|  5 | Hardik   |  27 | Bhopal    |  8500.00 |
|  6 | Komal    |  22 | MP        |  4500.00 |
|  7 | Muffy    |  24 | Indore    | 10000.00 |
+----+----------+-----+-----------+----------+

 下面是由 CUSTOMERS 表創(chuàng)建視圖的例子。該視圖包含來自 CUSTOMERS 表的顧客的名字(name)和年齡(age):

SQL > CREATE VIEW CUSTOMERS_VIEW AS
SELECT name, age
FROM  CUSTOMERS;

 現(xiàn)在,你就可以像查詢普通的數(shù)據(jù)表一樣查詢 CUSTOMERS_VIEW 了:

SQL > SELECT * FROM CUSTOMERS_VIEW;

 上述語句將會(huì)產(chǎn)生如下運(yùn)行結(jié)果:

+----------+-----+
| name     | age |
+----------+-----+
| Ramesh   |  32 |
| Khilan   |  25 |
| kaushik  |  23 |
| Chaitali |  25 |
| Hardik   |  27 |
| Komal    |  22 |
| Muffy    |  24 |
+----------+-----+

示例2

 下面是由 CUSTOMERS 表創(chuàng)建視圖的例子。該視圖包含來自 CUSTOMERS 表中年齡(age)為25的顧客的ADDRESS信息:

SQL > CREATE VIEW CUSTOMERS_ADDRESS AS
SELECT ADDRESS
FROM  CUSTOMERS;
WHERE AGE=25;

 我們可以像這樣查詢上面這個(gè) CUSTOMERS_ADDRESS 視圖:

SQL > SELECT * FROM CUSTOMERS_ADDRESS;

 我們也可以向查詢添加條件?,F(xiàn)在,我們僅僅需要查看 "Delhi" 的數(shù)據(jù):

SELECT * FROM CUSTOMERS_ADDRESS
WHERE ADDRESS='Delhi';


WITH CHECK OPTION


 WITH CHECK OPTION 是 CREATE VIEW 語句的一個(gè)可選項(xiàng)。

 WITH CHECK OPTION 用于保證所有的 UPDATE 和 INSERT 語句都滿足視圖定義中的條件。

 如果不能滿足這些條件,UPDATE 或 INSERT 就會(huì)返回錯(cuò)誤。

 下面的例子創(chuàng)建的也是 CUSTOMERS_VIEW 視圖,不過這次 WITH CHECK OPTION 是打開的:

CREATE VIEW CUSTOMERS_VIEW AS
SELECT name, age
FROM  CUSTOMERS
WHERE age IS NOT NULL
WITH CHECK OPTION;

 這里 WITH CHECK OPTION 使得視圖拒絕任何 AGE 字段為 NULL 的條目,因?yàn)橐晥D的定義中,AGE 字段不能為空。


更新視圖


 在SQL視圖上也可以使用修改數(shù)據(jù)的DML語句,如 INSERT、UPDATE和DELETE。

 視圖可以在特定的情況下更新:

  • SELECT 子句不能包含 DISTINCT 關(guān)鍵字
  • SELECT 子句不能包含任何匯總函數(shù)(summary functions)
  • SELECT 子句不能包含任何集合函數(shù)(set functions)
  • SELECT 子句不能包含任何集合運(yùn)算符(set operators)
  • SELECT 子句不能包含 ORDER BY 子句
  • 視圖不能包含連接操作符
  • 視圖不能包含偽列或表達(dá)式
  • FROM 子句中不能有多個(gè)數(shù)據(jù)表
  • WHERE 子句不能包含子查詢(subquery)
  • 查詢語句中不能有 GROUP BY 或者 HAVING
  • 計(jì)算得出的列不能更新
  • 視圖必須包含原始數(shù)據(jù)表中所有的 NOT NULL 列,從而使 INSERT 查詢生效。

 如果視圖滿足以上所有的條件,該視圖就可以被更新。下面的例子中,Ramesh 的年齡被更新了:

SQL > UPDATE CUSTOMERS_VIEW
      SET AGE = 35
      WHERE name='Ramesh';

 最終更新的還是原始數(shù)據(jù)表,只是其結(jié)果反應(yīng)在了視圖上。現(xiàn)在查詢原始數(shù)據(jù)表,SELECT 語句將會(huì)產(chǎn)生以下結(jié)果:

+----+----------+-----+-----------+----------+
| ID | NAME     | AGE | ADDRESS   | SALARY   |
+----+----------+-----+-----------+----------+
|  1 | Ramesh   |  35 | Ahmedabad |  2000.00 |
|  2 | Khilan   |  25 | Delhi     |  1500.00 |
|  3 | kaushik  |  23 | Kota      |  2000.00 |
|  4 | Chaitali |  25 | Mumbai    |  6500.00 |
|  5 | Hardik   |  27 | Bhopal    |  8500.00 |
|  6 | Komal    |  22 | MP        |  4500.00 |
|  7 | Muffy    |  24 | Indore    | 10000.00 |
+----+----------+-----+-----------+----------+

向視圖中插入新行


 可以向視圖中插入新行,其規(guī)則同(使用 UPDATE 命令)更新視圖所遵循的規(guī)則相同。

 這里我們不能向 CUSTOMERS_VIEW 視圖中添加新行,因?yàn)樵撘晥D沒有包含原始數(shù)據(jù)表中所有 NOT NULL 的列。否則的話,你就可以像在數(shù)據(jù)表中插入新行一樣,向視圖中插入新行。

 句法:

INSERT INTO view_name
VALUES (value1, value2, value3, ...);

刪除視圖中的行


 視圖中的數(shù)據(jù)行可以被刪除。刪除數(shù)據(jù)行與更新視圖和向視圖中插入新行遵循相同的規(guī)則。

 下面的例子將刪除 CUSTOMERS_VIEW 視圖中 AGE=22 的數(shù)據(jù)行:

SQL > DELETE FROM CUSTOMERS_VIEW
      WHERE age = 22;

 該語句最終會(huì)將原始數(shù)據(jù)表中對應(yīng)的數(shù)據(jù)行刪除,只不過其結(jié)果反應(yīng)在了視圖上?,F(xiàn)在查詢原始數(shù)據(jù)表,SELECT 語句將會(huì)產(chǎn)生以下結(jié)果:

+----+----------+-----+-----------+----------+
| ID | NAME     | AGE | ADDRESS   | SALARY   |
+----+----------+-----+-----------+----------+
|  1 | Ramesh   |  35 | Ahmedabad |  2000.00 |
|  2 | Khilan   |  25 | Delhi     |  1500.00 |
|  3 | kaushik  |  23 | Kota      |  2000.00 |
|  4 | Chaitali |  25 | Mumbai    |  6500.00 |
|  5 | Hardik   |  27 | Bhopal    |  8500.00 |
|  7 | Muffy    |  24 | Indore    | 10000.00 |
+----+----------+-----+-----------+----------+

刪除視圖


 很明顯,當(dāng)我們不再需要某個(gè)視圖的時(shí)候,需要有一種方式可以讓我們將其刪除。刪除視圖的語法非常簡單,如下所示:

DROP VIEW view_name;

 下面的例子展示了如何從 CUSTOMERS 表中刪除 CUSTOMERS_VIEW 視圖:

DROP VIEW CUSTOMERS_VIEW;


章節(jié)小測


 現(xiàn)在,通過以下題目測測看您對“SQL 使用視圖”的掌握程度吧!

 SQL 視圖:在本部分測驗(yàn)中,您將練習(xí)創(chuàng)建以及更新 SQL 視圖。

 點(diǎn)擊此處進(jìn)行測試>>

注:以上測試為付費(fèi)測試,高級(jí)VIP免費(fèi)


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)