我們如何使用子查詢建立一個 MySQL 檢視?


為了說明如何使用子查詢製作 MySQL 檢視,我們使用表“Cars”中的以下資料 −

mysql> select * from cars;
+------+--------------+---------+
| ID   | Name         | Price   |
+------+--------------+---------+
|    1 | Nexa         | 750000  |
|    2 | Maruti Swift | 450000  |
|    3 | BMW          | 4450000 |
|    4 | VOLVO        | 2250000 |
|    5 | Alto         | 250000  |
|    6 | Skoda        | 1250000 |
|    7 | Toyota       | 2400000 |
|    8 | Ford         | 1100000 |
+------+--------------+---------+
8 rows in set (0.08 sec)

現在,下面的查詢將使用子查詢建立名為“cars_avgprice”的檢視,子查詢將提供值以供檢視使用。子查詢必須用括號括起來。

mysql> Create view cars_avgprice AS SELECT NAME, Price FROM Cars WHERE price > (SELECT AVG(Price) from cars);
Query OK, 0 rows affected (0.12 sec)

mysql> Select * from cars_avgprice;
+--------+---------+
| NAME   | Price   |
+--------+---------+
| BMW    | 4450000 |
| VOLVO  | 2250000 |
| Toyota | 2400000 |
+--------+---------+
3 rows in set (0.03 sec)

如果我們單獨執行上述子查詢,便能瞭解檢視如何獲取其值 −

mysql> Select AVG(Price) from cars;
+--------------+
| AVG(Price)   |
+--------------+
| 1612500.0000 |
+--------------+
1 row in set (0.00 sec)

這就是為什麼檢視“cars_avgprice”具有售價高於平均價格(即 1,612,500)的汽車列表。

更新時間:2020 年 6 月 22 日

2K+ 檢視次數

開啟你的職業生涯之路

完成課程獲取認證

立即開始
廣告