栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

MySQL视图那些事儿

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

MySQL视图那些事儿

·

什么是视图?

view:站在不同的角度去看待同一份数据

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

表复制:

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语句;

用视图做什么?

我们可以面向视图对象进行增删改查,对视图对象的增删改查,会直接导致原表被操作!

//面向视图查询

mysql> select * from dept2_view; +--------+------------+-----------+ | DEPTNO | DNAME | LOC | +--------+------------+-----------+ | 10 | ACCOUNTING | NEW YORK | | 20 | Y閮ㄩ棬 | tianjin | | 30 | X閮ㄩ棬 | tianjin12 | | 50 | 浜轰簨閮? | 鍖椾含 | +--------+------------+-----------+

//面向视图插入

insert into dept2_view(deptno,dname,loc)values(70,'111','222');

//面向原表查询

mysql> select * from dept2; +--------+------------+-----------+ | DEPTNO | DNAME | LOC | +--------+------------+-----------+ | 10 | ACCOUNTING | NEW YORK | | 20 | Y閮ㄩ棬 | tianjin | | 30 | X閮ㄩ棬 | tianjin12 | | 50 | 浜轰簨閮? | 鍖椾含 | | 70 | 111 | 222 | +--------+------------+-----------+

//面向视图删除

delete from dept_view ;

 

在查询视图发现没有数据了

//查询原表数据

 

也没有数据了

//创建视图对象

mysql> 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';

//原表数据被更新

视图对象在实际开发中到底有什么用?

假设有一条非常复杂的SQL语句,而这条SQL语句需要在不同的位置上反复使用。每一次使用这个sql语句的时候都要重新编写,很长,很麻烦,怎么办?

答:可以把这条复杂的sql语句以视图对象的形式新建,在需要编写这条sql语句的位置直接使用视图对象,并且利于后期的维护,因为修改的时候也只需要修改一个位置就行,只需要修改视图对象所映射的SQL语句。

我们以后面向视图开发的时候,使用视图的时候可以像使用table一样。可以对视图进行增删改查等操作,视图不是在内存当中,视图对象也是存储在硬盘上的,不会消失。

提醒:视图对应的语句只能是DQL语句,但是视图对象创建完成之后,可以对视图进行增删改查等操作。

C:Create(增)

R:Retrive(查:检索)

U:Update(改)

D:Delete(删)

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/885976.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号