• MySql学习笔记10——视图介绍


    视图

    概述

    view

    view可以看作是一张“虚拟表”,(但是他也是会作为文件存在的)

    当我们通过复杂的查询语句获取一张表的时候,可以将这张表作为一个视图,和创建一个新表不同,在视图上进行的DML操作会对数据原本存在的表产生影响,也就是说,原表中的数据会被修改,但是创建新表,在新表中进行操作,不会对原表造成影响。

    视图就是个存放检索结果的临时表。

    创建视图,删除视图

    创建视图:

    create view 视图名称 as DQM语句(例如select查询语句);
    
    • 1

    删除视图:

    drop view 视图名称;
    
    • 1

    create view view_name as 这里的语句必须是DQL语句;

    视图的作用

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

    假设我们有一个复杂的SQL语句,这个语句需要在不同的位置上反复使用,但是每次写很长的程序就很慢。为了简化操作,可以使用视图,创建的视图对象,就是我们所需要反复操作的数据,之后我们想要修改这些数据,就省去了检索的步骤,可以直接对视图进行操作,达到对原表数据的增删查改。

    C:Create(增)
    R:Retrive(查:检索)
    U:Update(改)
    D:Delete(删)

    创建视图对象:

    create view 
    		emp_dept_view
    	as
    		select 
    			e.ename,e.sal,d.dname
    		from
    			emp e
    		join
    			dept d
    		on
    			e.deptno = d.deptno;
    			
    mysql> select * from emp_dept_view;
    +--------+---------+------------+
    | ename  | sal     | dname      |
    +--------+---------+------------+
    | SMITH  |  800.00 | RESEARCH   |
    | ALLEN  | 1600.00 | SALES      |
    | WARD   | 1250.00 | SALES      |
    | JONES  | 2975.00 | RESEARCH   |
    | MARTIN | 1250.00 | SALES      |
    | BLAKE  | 2850.00 | SALES      |
    | CLARK  | 2450.00 | ACCOUNTING |
    | SCOTT  | 3000.00 | RESEARCH   |
    | KING   | 5000.00 | ACCOUNTING |
    | TURNER | 1500.00 | SALES      |
    | ADAMS  | 1100.00 | RESEARCH   |
    | JAMES  |  950.00 | SALES      |
    | FORD   | 3000.00 | RESEARCH   |
    | MILLER | 1300.00 | ACCOUNTING |
    +--------+---------+------------+
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31

    对视图对象进行修改:

    mysql> update emp_dept_view set sal=1000 where dname='ACCOUNTING';
    Query OK, 3 rows affected (0.01 sec)
    Rows matched: 3  Changed: 3  Warnings: 0
    
    • 1
    • 2
    • 3

    查看原表中的数据,发现被修改了:

    mysql> select * from emp;
    +-------+--------+-----------+------+------------+---------+---------+--------+
    | EMPNO | ENAME  | JOB       | MGR  | HIREDATE   | SAL     | COMM    | DEPTNO |
    +-------+--------+-----------+------+------------+---------+---------+--------+
    |  7369 | SMITH  | CLERK     | 7902 | 1980-12-17 |  800.00 |    NULL |     20 |
    |  7499 | ALLEN  | SALESMAN  | 7698 | 1981-02-20 | 1600.00 |  300.00 |     30 |
    |  7521 | WARD   | SALESMAN  | 7698 | 1981-02-22 | 1250.00 |  500.00 |     30 |
    |  7566 | JONES  | MANAGER   | 7839 | 1981-04-02 | 2975.00 |    NULL |     20 |
    |  7654 | MARTIN | SALESMAN  | 7698 | 1981-09-28 | 1250.00 | 1400.00 |     30 |
    |  7698 | BLAKE  | MANAGER   | 7839 | 1981-05-01 | 2850.00 |    NULL |     30 |
    |  7782 | CLARK  | MANAGER   | 7839 | 1981-06-09 | 1000.00 |    NULL |     10 |
    |  7788 | SCOTT  | ANALYST   | 7566 | 1987-04-19 | 3000.00 |    NULL |     20 |
    |  7839 | KING   | PRESIDENT | NULL | 1981-11-17 | 1000.00 |    NULL |     10 |
    |  7844 | TURNER | SALESMAN  | 7698 | 1981-09-08 | 1500.00 |    0.00 |     30 |
    |  7876 | ADAMS  | CLERK     | 7788 | 1987-05-23 | 1100.00 |    NULL |     20 |
    |  7900 | JAMES  | CLERK     | 7698 | 1981-12-03 |  950.00 |    NULL |     30 |
    |  7902 | FORD   | ANALYST   | 7566 | 1981-12-03 | 3000.00 |    NULL |     20 |
    |  7934 | MILLER | CLERK     | 7782 | 1982-01-23 | 1000.00 |    NULL |     10 |
    +-------+--------+-----------+------+------------+---------+---------+--------+
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
  • 相关阅读:
    AUTOSAR汽车电子嵌入式编程精讲300篇-面向车载CAN网络的路由和ECU刷写方法 (下)
    Java中ExecutorService线程池的使用(Runnable和Callable多线程实现)
    动手学深度学习笔记-线性回归和softmax回归底层从零实现
    【附源码】计算机毕业设计JAVA研究生入学考试备考辅助系统
    CentOS7.9+Kubernetes1.28.3+Docker24.0.6高可用集群二进制部署
    聚观早报 | 首个“5G-A智慧家庭”发布;李鹏称5G-A是5G发展选择
    使用IVX来创造一个自己的3D小游戏【后台和中台、React Core、three.js、Pixi.js、Krpano、antD......】
    NPDP|作为产品经理,如何快速提升自身业务素养?
    Android 桌面小组件使用
    cognex Insight相机与机器人配合标定的方法(转载不易)
  • 原文地址:https://blog.csdn.net/Maxcu/article/details/132664687