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;
    
  • 相关阅读:
    duilib布局
    C++中嵌入网页(duilib编辑框的实现)
    拖拽的实现
    调试URL(写文件)
    如何使用DataBinder.Eval()方法进行数据绑定
    GridVew,DataList,Repeater分页用户控件(第一版)
    关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(转)
    使用PagedDataSource类实现DataList和Repeater控件的分页显示功能
    一个取得数据控件模板中输入框值的类
    在GridView中自定按钮,实现删除和更新
  • 原文地址:https://www.cnblogs.com/Lin2396/p/11631509.html
Copyright © 2011-2022 走看看