mysql视图原理与用法实例详解

 更新时间:2020年04月16日 10:43:32   作者:随风行云  
这篇文章主要介绍了mysql视图原理与用法,结合实例形式详细分析了mysql视图的概念、原理、使用方法及操作注意事项,需要的朋友可以参考下

本文实例讲述了mysql视图原理与用法。分享给大家供大家参考,具体如下:

本文内容:

  • 什么是视图
  • 创建视图
  • 查看视图
  • 视图的修改
  • 视图的删除
  • 视图的数据操作

首发日期:2018-04-13


什么是视图:

  • 视图是一种基于查询结果的虚拟表,数据来源的表称为基本表。
  • 视图的建立和删除不影响基本表。
  • 视图的插入,修改操作会影响基本表。
  • 如果视图来自多个基本表,那么不可以修改基本表。
  • 视图的用处:
    • 1.视图基于查询结果,使得视图可以隐藏基本表一些不该展示给用户的数据信息(比如某个开发人员需要用户信息表,但不应该展示给他用户的密码信息。)
    • 2.视图是一个虚拟表,可以将查询信息存储到视图中,这样可以便于操作。
    • ......


创建视图:

  • 语法:create view 视图名 as select语句 [with check option];【select语句可以多表查询结果:联合查询、连接查询】
    • with check option会依据where等条件语句来限制插入和修改操作(比如检索出来的视图数据是男的,不允许将男的改成女的)
        create view man_info as select * from student where gender="male";

补充:

  • 视图的创建还有一个可选项:视图算法(这里不讲述,想了解的可以百度)


查看视图:

  • 视图是一个虚拟表,针对表的查看语句都可以使用到视图中
    • 查看所有视图:show tables/views;
    • 查看视图结构:desc/describe/show columns from 视图名;
    • 查看视图创建语句:show create table/view 视图名;

视图的修改:

  • 有时候可能发生定义视图错误,所以这时候会执行修改视图操作。
  • 语法:alter view 视图名 as 新的select语句;
create view user_view as select * from user;
alter view user_view as select username,money from user;

补充:

  • 由于视图是一种虚拟表,还有一种可以修改视图的方法:create or replace view 视图创建语句;【将以新的视图覆盖旧视图】

视图的删除:

  • 语法:drop view 视图名[,视图名…];
  • 示例:
    drop view student_class,student_info;

视图的数据操作:

  • 如果视图来自多个基本表,那么不可以修改基本表。不过理论上update是允许的。

视图的数据查看:

  • 语法:select 字段列表 from 视图名;【与基本表的查询操作是一致的。】

视图的数据插入:

  • 数据来源自多个基本表时,无法进行插入操作。
  • 语法:insert into 视图名 values();【与基本表的插入操作是一致的。】
  • 注意:视图结构来自于基本表,所以要接受基本表的约束。如果某个字段不允许为空,但视图的插入操作又没赋值的话,会插入失败。

视图的数据修改:

  • 语法:update 视图名 set 字段名 = 值 where 条件;【与基本表的修改操作是一致的。】

视图的数据删除:

  • 数据来源自多个基本表时,无法进行删除操作。
  • 语法:delete from 视图名 where 条件;【与基本表的删除操作是一致的。】

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总

希望本文所述对大家MySQL数据库计有所帮助。

相关文章

  • MySQL随机查询记录的效率测试分析

    MySQL随机查询记录的效率测试分析

    以下的文章主要介绍的是MySQL使用rand 随机查询记录效率测试,我们大家一直都以为MySQL数据库随机查询的几条数据,就用以下的东东,其实其实际效率是十分低的
    2011-06-06
  • MySQL解析JSON格式字段并取出部分值方式

    MySQL解析JSON格式字段并取出部分值方式

    这篇文章主要介绍了MySQL解析JSON格式字段并取出部分值方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Centos7安装和配置Mysql5.7

    Centos7安装和配置Mysql5.7

    网上关于Linux安装mysql数据库的教程数不胜数,但是,大多教程都是漏洞百出。今天,为了帮助各位需要的人,从而写下Centos7安装配置mysql5.7的教程。
    2018-02-02
  • MySQL数据库大小写敏感的问题

    MySQL数据库大小写敏感的问题

    今天小编就为大家分享一篇关于MySQL数据库大小写敏感的问题,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • Centos6.9安装Mysql5.7.18步骤记录

    Centos6.9安装Mysql5.7.18步骤记录

    本文给大家详细介绍了Centos6.9安装Mysql5.7.18的步骤,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2017-06-06
  • MySQL数据操作-DML语句的使用

    MySQL数据操作-DML语句的使用

    这篇文章主要介绍了MySQL数据操作-DML语句的使用,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2020-11-11
  • 简单实现MySQL服务器的优化配置方法

    简单实现MySQL服务器的优化配置方法

    我们今天主要向大家描述的是MySQL服务器的优化配置的时机操作步骤,以及在MySQL服务器的优化配置的的过程中值得我们主义的事项的介绍。
    2011-03-03
  • mysql全量备份、增量备份实现方法

    mysql全量备份、增量备份实现方法

    这篇文章主要介绍了mysql全量备份、增量备份实现方法,需要的朋友可以参考下
    2016-12-12
  • MySQL清空数据表的方法实例与分析

    MySQL清空数据表的方法实例与分析

    这篇文章给大家详细介绍了MySQL清空数据表的方法,文中给出了实例代码,对大家学习使用MySQL具有一定的参考借鉴价值,有需要的可以参考借鉴,下面来一起看看吧。
    2016-10-10
  • MySQL数据库InnoDB引擎主从复制同步经验总结

    MySQL数据库InnoDB引擎主从复制同步经验总结

    这篇文章主要介绍了MySQL数据库InnoDB引擎主从复制同步经验总结,本文总结了设置主从复制时遇到的一些错误和解决方法,需要的朋友可以参考下
    2015-01-01

最新评论