MySQL查看视图

【图书推荐】《MySQL 9从入门到性能优化(视频教学版)》-CSDN博客

《MySQL 9从入门到性能优化(视频教学版)(数据库技术丛书)》(王英英)【摘要 书评 试读】- 京东图书 (jd.com)

MySQL9数据库技术_夏天又到了的博客-CSDN博客

查看视图是查看数据库中已存在的视图的定义。查看视图必须要有SHOW VIEW权限,MySQL数据库下的user表中保存着这个信息。查看视图的方法包括DESCRIBE、SHOW TABLE STATUS和SHOW CREATE VIEW,本节将介绍查看视图的各种方法。

9.3.1 使用DESCRIBE语句查看视图基本信息

DESCRIBE可以用来查看视图,具体的语法如下:

复制代码
DESCRIBE 视图名;

【例9.4】通过DESCRIBE语句查看视图view_t的定义,SQL语句如下:

复制代码
DESCRIBE view_t;

语句执行结果如下:

复制代码
mysql> DESCRIBE view_t;
+-----------------+------------+------+-----+---------+-------+
| Field           | Type       | Null | Key | Default | Extra |
+-----------------+------------+------+-----+---------+-------+
| quantity        | int        | YES  |     | NULL    |       |
| price           | int        | YES  |     | NULL    |       |
| quantity *price | bigint(21) | YES  |     | NULL    |       |
+-----------------+------------+------+-----+---------+-------+

结果显示出了视图的字段定义、字段的数据类型、是否为空、是否为主/外键、默认值和额外信息。

DESCRIBE一般情况下都简写成DESC,DESC命令的执行结果和DESCRIBE命令的执行结果是一样的。

9.3.2 使用SHOW TABLE STATUS语句查看视图基本信息

查看视图的信息也可以通过SHOW TABLE STATUS语句完成,具体的语法如下:

复制代码
SHOW TABLE STATUS LIKE '视图名';

【例9.5】使用SHOW TABLE STATUS命令查看视图信息,SQL语句如下:

复制代码
SHOW TABLE STATUS LIKE 'view_t' \G

语句执行结果如下:

复制代码
mysql> SHOW TABLE STATUS LIKE 'view_t' \G
*************************** 1. row ***************************
           Name: view_t
         Engine: NULL
        Version: NULL
     Row_format: NULL
           Rows: NULL
 Avg_row_length: NULL
    Data_length: NULL
Max_data_length: NULL
   Index_length: NULL
      Data_free: NULL
 Auto_increment: NULL
    Create_time: 2027-07-25 09:06:24
    Update_time: NULL
     Check_time: NULL
      Collation: NULL
       Checksum: NULL
 Create_options: NULL
        Comment: VIEW

执行结果显示,表的Comment的值为VIEW,说明该表为视图;其他的信息为NULL,说明这是一张虚表。

用同样的语句来查看一下数据表tv的信息,执行结果如下:

复制代码
mysql> SHOW TABLE STATUS LIKE 'tv' \G
*************************** 1. row ***************************
           Name: tv
         Engine: InnoDB
        Version: 10
     Row_format: Dynamic
           Rows: 1
 Avg_row_length: 16384
    Data_length: 16384
Max_data_length: 0
   Index_length: 0
      Data_free: 0
 Auto_increment: NULL
    Create_time: 2024-03-17 09:05:49
    Update_time: 2024-03-17 09:05:56
     Check_time: NULL
      Collation: utf8mb4_0900_ai_ci
       Checksum: NULL
 Create_options:
        Comment:

从查询的结果来看,这里的信息包含了存储引擎、创建时间等,并且Comment信息为空。这就是视图和表的区别。

9.3.3 使用SHOW CREATE VIEW语句查看视图详细信息

使用SHOW CREATE VIEW语句可以查看视图详细定义,语法如下:

复制代码
SHOW CREATE VIEW 视图名;

【例9.6】使用SHOW CREATE VIEW查看视图的详细定义,SQL语句如下:

复制代码
SHOW CREATE VIEW view_t \G

语句执行结果如下:

复制代码
mysql> SHOW CREATE VIEW view_t \G
*************************** 1. row ***************************
                View: view_t
         Create View: CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `view_t` AS select `tv`.`quantity` AS `quantity`,`tv`.`price` AS `price`,(`tv`.`quantity` * `tv`.`price`) AS `quantity *price` from `tv`
character_set_client: utf8mb4
collation_connection: utf8mb4_0900_ai_ci

执行结果中显示了视图的名称、创建视图的语句等信息。

9.3.4 在views表中查看视图详细信息

在MySQL中,information_schema数据库下的views表中存储了所有视图的定义。通过对views表进行查询,可以查看数据库中所有视图的详细信息,查询语句如下:

复制代码
SELECT * FROM information_schema.views;

【例9.7】在views表中查看视图的详细定义,SQL语句如下:

复制代码
mysql> SELECT * FROM information_schema.views\G
*** 1. row ***
       TABLE_CATALOG: def
        TABLE_SCHEMA: chapter11db
          TABLE_NAME: stu_glass
     VIEW_DEFINITION: select `chapter11db`.`student`.`s_id` AS `id`,`chapter11db`.`student`.`name` AS `name`,`
chapter11db`.`stu_info`.`glass` AS `glass` from `chapter11db`.`student` join `chapter11db`.`stu_info` where (`
chapter11db`.`student`.`s_id` = `chapter11db`.`stu_info`.`s_id`)
        CHECK_OPTION: NONE
        IS_UPDATABLE: YES
             DEFINER: root@localhost
       SECURITY_TYPE: DEFINER
CHARACTER_SET_CLIENT: gbk
COLLATION_CONNECTION: gbk_chinese_ci
*** 2. row ***
       TABLE_CATALOG: def
        TABLE_SCHEMA: chapter11db
          TABLE_NAME: view_t
     VIEW_DEFINITION: select `chapter11db`.`t`.`quantity` AS `quantity`,`chapter11db`.`t`.`price` AS `price`,(
`chapter11db`.`t`.`quantity` * `chapter11db`.`t`.`price`) AS `quantity *price` from `chapter11db`.`t`
        CHECK_OPTION: NONE
        IS_UPDATABLE: YES
             DEFINER: root@localhost
       SECURITY_TYPE: DEFINER
CHARACTER_SET_CLIENT: gbk
COLLATION_CONNECTION: gbk_chinese_ci
*** 3. row ***
       TABLE_CATALOG: def
        TABLE_SCHEMA: chapter11db
          TABLE_NAME: view_t2
     VIEW_DEFINITION: select `chapter11db`.`t`.`quantity` AS `qty`,`chapter11db`.`t`.`price` AS `price`,(`chap
ter11db`.`t`.`quantity` * `chapter11db`.`t`.`price`) AS `total` from `chapter11db`.`t`
        CHECK_OPTION: NONE
        IS_UPDATABLE: YES
             DEFINER: root@localhost
       SECURITY_TYPE: DEFINER
CHARACTER_SET_CLIENT: gbk
COLLATION_CONNECTION: gbk_chinese_ci
3 rows in set (0.03 sec)

查询的结果中显示了当前已经定义的所有视图的详细信息,包括前面定义的3个名称为"stu_glass""view_t"和"view_t2"的视图的详细信息。

相关推荐
杨云龙UP5 分钟前
CentOS Linux 7 (Core)上部署Oracle 11g、19C RAC详细图文教程
数据库·oracle
雨白7 分钟前
OkHttp 源码解析:enqueue 非同步流程与 Dispatcher 调度
android
ezl1fe16 分钟前
RAG 每日一技(十八):手写SQL-RAG太累?LangChain的SQL智能体(Agent)前来救驾!
数据库·人工智能·后端
小咖张22 分钟前
spring声明式事务,finally 中return对事务回滚的影响
数据库·java 声明式事务
JSON_L24 分钟前
MySQL 加锁与解锁函数
数据库·mysql
风往哪边走1 小时前
自定义仿日历组件弹框
android
没有了遇见1 小时前
Android 外接 U 盘开发实战:从权限到文件复制
android
白鲸开源1 小时前
收藏!史上最全 Apache SeaTunnel Source 连接器盘点 (2025版),一篇通晓数据集成生态
大数据·数据库·开源
MonKingWD2 小时前
MySQL事务篇-事务概念、并发事务问题、隔离级别
数据库·后端·mysql
Monkey-旭2 小时前
Android 文件存储机制全解析
android·文件存储·kolin