• 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;
    
  • 相关阅读:
    排列 [计数dp]
    排列 [计数dp]
    函数 [计数]
    多态
    继承2
    2018年蓝桥杯b组国赛真题
    c++的继承
    运算符2
    运算符重载
    拷贝构造
  • 原文地址:https://www.cnblogs.com/Lin2396/p/11631509.html
Copyright © 2020-2023  润新知