我们如何使用子查询创建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

回到顶部