我们如何使用子查询创建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);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”具有价格高于平均价格(即1612500)的汽车列表的原因。
以上是 我们如何使用子查询创建MySQL视图? 的全部内容, 来源链接: utcz.com/z/354935.html