视图
在 SQL 中,视图(View)是基于 SQL 语句的结果集的虚拟表。 它包含与真实的表一样的行和列。 每次查询视图时,都会运行该视图的查询。
在以下情况下,我们可以使用视图:
- 简化复杂查询,避免每次查询都重复编写和发送复杂语句。
- 对特定用户开放读取权限,限制一些列和行的读取,保证数据安全和隔离。
可以使用 CREATE VIEW
语句创建视图。
视图示例
CREATE VIEW cpu_monitor AS
SELECT cpu, host, ts FROM monitor;
这个视图的名称是 cpu_monitor
,在 AS
之后的查询语句是用于呈现数据的 SQL 语句。查询视图:
SELECT * FROM cpu_monitor;
结果示例:
+------+-----------+---------------------+
| cpu | host | ts |
+------+-----------+---------------------+
| 0.5 | 127.0.0.1 | 2023-12-13 02:05:41 |
| 0.3 | 127.0.0.1 | 2023-12-13 02:05:46 |
| 0.4 | 127.0.0.1 | 2023-12-13 02:05:51 |
| 0.3 | 127.0.0.2 | 2023-12-13 02:05:41 |
| 0.2 | 127.0.0.2 | 2023-12-13 02:05:46 |
| 0.2 | 127.0.0.2 | 2023-12-13 02:05:51 |
+------+-----------+---------------------+
通过 WHERE
查询视图:
SELECT * FROM cpu_monitor WHERE host = '127.0.0.2';
结果示例:
+------+-----------+---------------------+
| cpu | host | ts |
+------+-----------+---------------------+
| 0.3 | 127.0.0.2 | 2023-12-13 02:05:41 |
| 0.2 | 127.0.0.2 | 2023-12-13 02:05:46 |
| 0.2 | 127.0.0.2 | 2023-12-13 02:05:51 |
+------+-----------+---------------------+
创建一个从两个表联合查询数据的视图:
CREATE VIEW app_cpu_monitor AS
SELECT cpu, latency, host, ts FROM monitor LEFT JOIN app_monitor
ON monitor.host = app_monitor.host AND monitor.ts = app_monitor.ts
然后可以像查询一个单表数据一样查询这个视图:
SELECT * FROM app_cpu_monitor WHERE host = 'host1'
更新视图
使用 CREATE OR REPLACE VIEW
来更新视图,如果视图不存在,则会创建:
CREATE OR REPLACE VIEW memory_monitor AS
SELECT memory, host, ts FROM monitor;
显示视图定义
通过 SHOW CREATE VIEW view_name
语句来显示创建视图的 CREATE VIEW
语句:
SHOW CREATE VIEW cpu_monitor;
+-------------+--------------------------------------------------------------+
| View | Create View |
+-------------+--------------------------------------------------------------+
| cpu_monitor | CREATE VIEW cpu_monitor AS SELECT cpu, host, ts FROM monitor |
+-------------+--------------------------------------------------------------+
列出视图
使用 SHOW VIEWS
语句查找所有视图:
> SHOW VIEWS;
+----------------+
| Views |
+----------------+
| cpu_monitor |
| memory_monitor |
+----------------+
当然,像 SHOW TABLES
一样,它也支持 LIKE
和 WHERE
:
> SHOW VIEWS like 'cpu%';
+-------------+
| Views |
+-------------+
| cpu_monitor |
+-------------+
1 row in set (0.02 sec)
> SHOW VIEWS WHERE Views = 'memory_monitor';
+----------------+
| Views |
+----------------+
| memory_monitor |
+----------------+
删除视图
使用 DROP VIEW
语句删除视图:
DROP VIEW cpu_monitor;
如果希望在视图不存在时不报错,可以使用:
DROP VIEW IF EXISTS test;