SQL学习笔记——视图

视图(view):站在不同的角度去看待同一份数据

创建视图对象、删除视图对象

表复制:create table dept2 as select * from dept;
dept2表中数据:
select * from dept2;

  • 创建视图对象:
    create view dept2_view as select * from emp;

  • 删除视图对象:
    drop view dept2_view;

注意:只有DQL语句才能以view的形式创建
create view view_name as DQL语句;

作用:

可以面向视图对象进行增删改查,
对视图对象的增删改查,会导致原表被操作!
(视图的特点:通过对视图的操作,会影响到原表数据。)

原表
  • 面向视图查询
    select * from dept2_view ;

  • 面向视图插入
    insert into dept2_view(deptno , dname , loc) values(60 ,' SALES','BEIJING' );
    mysql > select * from dept2 ;

原表数据变了
  • 面向视图删除
    delete from dept2_view;

  • 查询原表数据
    select * from dept2;

删除后,原表数据清空了

//创建视图对象
create view
  emp_dept_view
as
  select
    e.ename , e.sal , d.dname
  from
    emp e
  join
    dept d
  on
    e . deptno = d.deptno;

视图的使用场景(方便、简化开发、利于维护)

  假设有一条非常复杂的SQL语句,而这条SQL语句需要在不同的位置上反复使用每一次使用这个sql语句的时候都需要重新编写,可以把这条复杂的SQL语句以视图对象的形式新建。
  在需要编写这条SQL语句的位置直接使用视图对象,可以大大简化开发。
  并且利于后期的维护,因为修改的时候也只需要修改一个位置就行,只需要修改视图对象所映射的SQL语句。

我们以后面向视图开发的时候,使用视图的时候可以像使用table一样。可以对视图进行增删改查等操作。视图不是在内存当中,视图对象也是存储在硬盘上的,不会消失。

视图对应的语句只能是DQL语句
但是视图对象创建完成后,可以对视图进行增删改查(CRUD,C:Create 增,R:Retrive 查/检索,U:Update 改,D:Delete 删)
create view
  emp_dept_view
as
  DQL

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 数据库 数据库介绍 之前通过IO流操作文件保存数据弊端1、效率低2、一般只能保存少量的数据3、只能保存文本数据 什...
    沉浮_0644阅读 4,223评论 0 0
  • 写在前面:本篇博客大部分内容参考数据库系统概念(本科教学版)第四章(第三章的多表部分会挪到这一部分讲)笔者接下来的...
    SunnyQjm阅读 3,318评论 0 2
  • 1.什么是视图? view:站在不同的角度去看待同一份数据。 2.如何创建、删除视图对象? 创建视图对象:crea...
    Maple0831阅读 3,081评论 0 0
  • 数据库对于后端开发来说是必不可少所要用到的,而MySQL数据库是其中的主流之一,在中小型公司中使用的较为广泛,作为...
    Steven_SHH阅读 5,309评论 0 2
  • 1、组函数:组函数作用于一组数据,并对一组数据返回一个值。 AVG 平均值COUNT计数MAX最大值MIN最小值S...
    Shaw_Chen阅读 3,538评论 0 2

友情链接更多精彩内容