MySQL视图的概念、创建、查看、删除和修改详解


当前第2页 返回上一页

视图也是一张表,只是这张表比较特殊,是一张虚拟的表,所以同样可以使用DESCRIBE语句来查看视图的基本定义。DESCRIBE语句查看视图的语法如下:

DESCRIBE | DESC viewname;

例如查看上面创建的视图

2.使用SHOW TABLES语句查看视图基本信息

从MySQL 5.1版本开始,执行SHOW TABLES语句时不仅会显示表的名字,同时也会显示视图的名字。 

show tables

3.使用 show create view/table 语句查看视图创建信息

SHOW CREATE TABLE|VIEW viewname;

四、更新视图数据 

更新视图是指通过视图来插入(INSERT)、更新(UPDATE)和删除(DELETE)表中的数据。因为视图实质是一个虚拟表,其中没有数据,通过视图更新时都是转换到基本表更新。更新视图时,只能更新权限范围内的数据,超出范围就不能更新了。

update view_student set name='小王' where name='小王王';

不能更新的情况:

  • 视图中包含SUM()、COUNT()、MAX()和MIN()等函数;
  • 视图中包含UNION、UNION ALL、DISTINCT、GROUP BY和HAVING等关键字;
  • 视图对应的表存在没有默认值的列,而且该列没有包含在视图里;
  • 包含子查询的视图;
  • 其他特殊情况;

例如更改view_student_teacher时

五、修改视图 

修改视图是指修改数据库中存在的视图,当基本表的某些字段发生变化的时候,可以通过修改视图来保持与基本表的一致性。ALTER语句来修改视图。 

ALTER VIEW viewname[columnlist]   
AS SELECT statement

这个语法中的所有关键字和参数除了alter 外,其他都和创建视图是一样的。

例如修改视图view_student_teacher

SQL语句示例

alter view view_student_teacher 
as select teacher,class,name,sex 
    from class 
        left join student on class.id=student.class_id;

注意,当真实表中修改了某个存在视图中的字段时,这个视图也需要跟着变,否则会变成无效的视图

例如,修改了student表中的name字段

alter table student change column name name1 varchar(64);
select * from view_student_teaccher;

这时候就需要将视图也跟着修改

alter view view_student_teacher as select teacher,class,name1,sex 
    from class 
        left join student on class.id=student.class_id;

六、删除视图 

删除视图是指删除数据库中已存在的视图。删除视图时,只能删除视图的定义,不会删除数据。

在MySQL中,可使用DROP VIEW语句来删除视图,但是用户必须拥有DROP权限。删除视图的语法如下:

DROP VIEW viewname [,viewnamen];
参数viewname表示所要删除视图的名称,可同时指定删除多个视图。 

总结

到此这篇关于MySQL视图的概念、创建、查看、删除和修改的文章就介绍到这了,更多相关MySQL视图创建 查看 删除和修改内容请搜索

更多Mysql内容来自木庄网络博客


标签:Mysql

返回前面的内容

相关阅读 >>

带你5分钟读懂mysql字符集设置

mysql8.0修改密码的正确姿势分享

mysql workbench是什么

如何去除mysql表中的 r n

mysql事务之acid特性(详解)

关于mysql报警的一次分析处理详解

《阿里巴巴java开发手册》里面写超过三张表禁止join,这是为什么?

linux下忘记mysql数据库密码的解决方法

mysql黑框怎么改密码?mysql黑窗口怎么改密码?

简单介绍mysql中的事务机制

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...