当前位置: 首页 > news >正文

mysql中的视图

1、什么是视图?
    view:站在不同的角度去看待同一份数据。

2、怎么创建视图对象?怎么删除视图对象?

    表复制:
    mysql> create table dept2 as select * from dept;

    创建视图对象:
        create view dept2_view as select * from dept2;
    删除视图对象:
        drop view dept2_view;   
    注意:只有DQL语句才能以view的形式创建。
        create view view_name as 这里的语句必须是DQL语句;

3、用视图做什么?

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

    //面向视图查询
    select * from dept2_view; 

    // 面向视图插入
    insert into dept2_view(deptno,dname,loc) values(60,'SALES', 'BEIJING');

    // 查询原表数据

    // 面向视图删除
    mysql> delete from dept2_view;

    // 查询原表数据
    mysql> select * from dept2;
    Empty set (0.00 sec) 

    // 创建视图对象
    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;
    +--------+---------+------------+

    // 面向视图更新
    update emp_dept_view set sal = 1000 where dname = 'ACCOUNTING';

    // 原表数据被更新
    mysql> select * from emp;

2.4、视图对象在实际开发中到底有什么用?《方便,简化开发,利于维护》

        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。
            CRUD是在公司中程序员之间沟通的术语。一般我们很少说增删改查。
            一般都说CRUD。

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

http://www.lryc.cn/news/339326.html

相关文章:

  • 树莓派点亮双色LED
  • DAY27| 39. 组合总和 ,40.组合总和II ,131.分割回文串
  • 24年重庆三支一扶报名照不通过怎么处理?
  • 20240409在全志H3平台的Nano Pi NEO CORE开发板上运行Ubuntu Core16.04时跑通4G模块EC200A-CN【PPP模式】
  • 【示例】MySQL-不同case下索引的使用分析
  • MySQL表空间管理与优化(8/16)
  • 杂货铺 | Linux虚拟机Ubuntu操作系统下设置共享文件夹(以及找不到hgfs文件夹怎么办)
  • 《HF经理》:二认知误区
  • ELK日志分析系统之Zookeeper
  • 家居网购项目(Ajax验证用户名+上传图片)
  • 09 Php学习:超级全局变量
  • 【Java】SpringBoot快速整合mongoDB
  • UI设计的未来发展
  • 推荐系统学习记录——连续的嵌入空间
  • 【Entity Framework】你要知道EF中功能序列与值转换
  • 顶顶通呼叫中心中间件-SIP分机安全(mod_cti基于FreeSWITCH)
  • CountDownLatch
  • Vue3中的组合式API与选项式API:深入理解与比较
  • 接口自动化测试实战之接口概念、项目简介及测试流程问答!
  • 浏览器工作原理与实践--跨站脚本攻击(XSS):为什么Cookie中有HttpOnly属性
  • Ubuntu配置VScode的C++环境
  • 使用Code开发Django_模版和CSS
  • Llama 3下月正式发布,继续开源!
  • 有图片转成PDF文件格式的方法吗?分享图片转成PDF文件的方法
  • 数据结构---绪论
  • matlab 安装 mingw64(6.3.0),OPENEXR
  • 最新彩虹知识付费商城源码 V3.4
  • Redis实现延迟任务的几种方案
  • 一种springboot请求参数校验的实现方案
  • 盒子模型+响应式布局 + 原型链与继承