mysql视图可以完成的操作_MySQL视图操作

本文介绍了MySQL视图的概念,如视图是内存中的临时表,并提供了数据准备的示例。详细讲解了视图的创建、替换、删除以及如何使用视图进行连表查询。此外,还阐述了视图的增删改操作,强调这些操作会直接影响到基础表。
摘要由CSDN通过智能技术生成

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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值