zoukankan      html  css  js  c++  java
  • MySQL视图操作

    MySQL视图操作

    视图:视图是存在在内存中的临时表

    数据准备

    CREATE TABLE `emp`  (
      `id` int(0) NOT NULL AUTO_INCREMENT,
      `name` varchar(10) NOT NULL,
      `gender` enum('男','女','未知') NULL DEFAULT '未知',
      `age` int(0) NULL DEFAULT 0,
      `salary` decimal(5,2) NULL DEFAULT 0,
      `area` varchar(20) NULL DEFAULT '中国',
      `port` varchar(20) DEFAULT '未知',
      `dep` varchar(20),
      PRIMARY KEY (`id`)
    );
    
    INSERT INTO `emp` VALUES 
    	(1, 'yangsir', '男', 42, 10.50, '上海', '浦东', '教职部'),
    	(2, 'engo', '男', 38, 9.4, '山东', '济南', '教学部'),
    	(3, 'jerry', '女', 30, 3.0, '江苏', '张家港', '教学部'),
    	(4, 'tank', '女', 28, 2.4, '广州', '广东', '教学部'),
    	(5, 'jiboy', '男', 28, 2.4, '江苏', '苏州', '教学部'),
    	(6, 'zero', '男', 18, 8.8, '中国', '黄浦', '咨询部'),
    	(7, 'owen', '男', 18, 8.8, '安徽', '宣城', '教学部'),
    	(8, 'jason', '男', 28, 9.8, '安徽', '巢湖', '教学部'),
    	(9, 'ying', '女', 36, 1.2, '安徽', '芜湖', '咨询部'),
    	(10, 'kevin', '男', 36, 5.8, '山东', '济南', '教学部'),
    	(11, 'monkey', '女', 28, 1.2, '山东', '青岛', '教职部'),
    	(12, 'san', '男', 30, 9.0, '上海', '浦东', '咨询部'),
    	(13, 'san1', '男', 30, 6.0, '上海', '浦东', '咨询部'),
    	(14, 'san2', '男', 30, 6.0, '上海', '浦西', '教学部');
    

    一、视图的创建

    视图的创建依赖select语句,所有就是select语句操作的结果形参的表

    # 语法:
    mysql>: create view 视图名[(别名们)] as select 语句;
    eg>: create view v1 as select dep, max(salary) from emp group by dep;
    
    # 创建或替换视图
    mysql>: create or replace 视图名[(别名们)] as select 语句;
    mysql>: alter 视图名[(别名们)] as select 语句;
    
    eg>: create or replace view v1(dep_name, max_salary) as select dep, max(salary) from emp group by dep;
    eg>: alter view v1(name, salary) as select dep, max(salary) from emp group by dep;
    
    # 删除视图
    mysql>: drop view 视图名
    eg>: drop view v1;
    
    # 视图可以作为正常表完成连表查询
    select name, dep_name, salary 
    from emp join v1 
    on emp.dep=v1.dep_name and emp.salary=v1.max_salary;
    

    二、视图的增删改

    前提:视图的增删改操作可以直接映射给真实表(本质就是对真实表进行操作)

    # 视图可以完成增删改,增删改本质是直接对创建视图的真实表进行操作
    create or replace view v2 as select id,name,age,salary from emp;
    update v2 set salary=salary+1 where id=1;
    delete from v2 where id=1;
    
    create or replace view v3 as select * from emp;
    insert into v3 values(1, 'yangsir', '男', 66, 1.11, '上海', '那噶的', '教职部');
    
    # 总结:操作视图,会影响真实表,反之也会影响
    update emp set salary=salary+1 where id=1;
    
  • 相关阅读:
    HDU 5446 CRT+Lucas+快速乘
    awk的用法
    【福利】小程序开发资源干货汇总
    前端css常用的选择小汇
    前端css常用的选择小汇
    前端,Java,产品经理,微信小程序,Python等资源合集大放送
    前端,Java,产品经理,微信小程序,Python等资源合集大放送
    bootstrap+fileinput插件实现可预览上传照片功能
    bootstrap+fileinput插件实现可预览上传照片功能
    Jquery前端分页插件pagination同步加载和异步加载
  • 原文地址:https://www.cnblogs.com/Lin2396/p/11631509.html
Copyright © 2011-2022 走看看