第12章:视图

news2024/11/29 2:31:52

一、视图

1.常见的数据库对象

①表table:表是存储数据的逻辑单元,行和列形式存在。列是字段,行是记录。

②数据字典:系统表,存放数据库相关信息的表。系统表的数据通常是数据库系统维护。

③约束constraint:执行数据校验规则,用于保证数据完整性

④视图view:一个或多个表里的数据的逻辑显示,视图不存储数据

⑤索引index:用于提高查询性能,相当于书的目录。

⑥存储过程procedure:完成一次完整的业务处理,没有返回值。但可以传出参数将多个值传给调用函数

⑦存储函数:用于完成一次的特定计算,具有一个返回值

⑧触发器:相当于一个事件监听器,当数据库发生特定事件时,触发器被触。完成相应的处理。

2.视图概述

 

2.1为什么使用视图?

视图是使用表的一部分,也可以针对不同的用户制定不同的查询视图。

2.2 视图的理解

①视图是一种虚拟表,不具有数据的,占用很少的空间。

②视图建立在已有表的基础上,视图赖以建立的表是基表。

③视图的数据进行增加、删除和修改,数据表的数据也发生变化。

④把视图理解为存储起来的select语句

⑤视图应用在大型项目,不针对于小型项目

⑥视图优点简化查询,控制数据的访问

3.创建视图

 

3.1创建单表视图

create view 视图名称
as
select 语句

 举例①

create view vu_emp1
AS
select employee_id,last_name,salary
from emps

查看视图

select * from vu_emp1;

举例② 查询语句字段起别名作为视图的字段名

create view vu_emp2
as
select employee_id emp_id,last_name lname,salary
from emps
where salary>8000;

 查看视图

select * from vu_emp2;

举例③起别名 视图和查询的字段名依次匹配

create view vu_emp3(emp_id,lname,monthly_sal)
as
select employee_id,last_name,salary
from emps
where salary>8000;

 查看视图

select * from vu_emp3;

举例④视图中的字段在基表中没有对应的

create view vu_emp_sal
as 
select department_id,avg(salary) avg_sal
from emps
where department_id is not NULL
group by department_id;

 查看视图

select * from vu_emp_sal;

3.2创建多表联合视图

create view vu_emp_dept
as 
select e.employee_id,e.department_id,d.department_name
from emps e
join depts d on e.department_id=d.department_id;
select * from vu_emp_dept;

查看视图

select * from vu_emp_dept;

 3.3利用视图对数据进行格式化:员工姓名(部门名)

create view vu_lname_empname
as
select concat(e.last_name,'(',d.department_name,')'),e.salary
from emps e
join depts d on e.department_id=d.department_id;

查看视图

select * from vu_lname_empname;

 3.4 基于视图创建视图

select * from vu_emp1;

 基于vu_emp1创建视图

create view vu_emp4
as 
select employee_id,last_name
from vu_emp1

查看vu_emp4

select * from vu_emp4

4.查看视图

①查看数据库的表对象、视图对象

show tables;

②查看视图的结构

desc 视图名称

 

③查看视图的属性信息

# 查看视图信息(显示数据表的存储引擎、版本、数据行数和数据大小等)

执行结果显示,注释Comment为VIEW,说明该表为视图,其他的信息为NULL,说明这是一个虚表。

show table status like '视图名称'

④视图的详细定义信息

show create view 视图名称

 

5.更新视图的数据—跟更新表格一样

举例①修改

update vu_emp1

set salary = 20000

where employee_id = 101;

视图和表格同时修改

举例②删除

delete

from vu_emp1

where employee_id=101

5.1不可更新视图的情况

①视图的更新必须要和基表存在一对一的关系

②出现多表查询的视图,聚合函数…

虽然可以更新视图数据,但总的来说,视图作为虚拟表,主要用于方便查询,不建议更新视图的

数据。对视图数据的更改,都是通过对实际数据表里数据的操作来完成的。

6.修改、删除视图

6.1修改视图

ALTER VIEW 视图名称

AS

查询语句

6.2删除视图

DROP VIEW 视图名;

7.总结

7.1视图的优点

①简化查询,操作简单

②减少数据的冗余

在使用的时候,我们要通过定义视图的查询语句来获取结果集。而视图本身不存储数据,不占用数据存储的资源,减少了数据冗余。

③数据安全

MySQL将用户对数据的 访问限制 在某些数据的结果集上,而这些数据的结果集可以使用视图来实现。用户不必直接查询或操作数据表。这也可以理解为视图具有 隔离性 。视图相当于在用户和实际的数据表之间加了一层虚拟表。

 

 

4. 适应灵活多变的需求

5. 能够分解复杂的查询逻辑

7.2视图的缺点

①表的结构发生变化,对应的视图需要及时进行维护。特别是嵌套视图,维护复杂,可读性不好。

②视图过多,维护成本高

8课后练习

练习一

#1. 使用表employees创建视图employee_vu,其中包括姓名(LAST_NAME),员工号(EMPLOYEE_ID),部门号(DEPARTMENT_ID)

create view employee_vu
as
select last_name,employee_id,department_id
from emps

#2. 显示视图的结构

desc  employee_vu

#3. 查询视图中的全部内容

select * from employee_vu

#4. 将视图中的数据限定在部门号是80的范围内

alter view employee_vu
as
select last_name,employee_id,department_id
from emps
where department_id=80

练习二

CREATE TABLE emps

AS

SELECT * FROM atguigudb.employees;

#1. 创建视图emp_v1,要求查询电话号码以‘011’开头的员工姓名和工资、邮箱

create view emp_v1
as
select last_name,salary,email,phone_number
from emps
where phone_number like '011%'

#2. 要求将视图 emp_v1 修改为查询电话号码以‘011’开头的并且邮箱中包含 e 字符的员工姓名和邮箱、电话号码

alter view  emp_v1
as
select last_name,salary,email,phone_number
from emps
where email like '%e%' and phone_number like '011%'

#3. emp_v1 插入一条记录,是否可以?

失败了,在表里有些非空字段没有默认值,在视图里面没有出现此字段

#4. 修改emp_v1中员工的工资,每人涨薪1000

update emp_v1
set salary=salary+1000

#5. 删除emp_v1中姓名为Olsen的员工

delete from emp_v1
where last_name='Olsen'

#6. 创建视图emp_v2,要求查询部门的最高工资高于 12000 的部门id和其最高工资

create view emp_v2
as
select department_id,max(salary)
from emps
group by department_id having max(salary)>12000

#7. emp_v2 中插入一条记录,是否可以?

不可以,聚合函数

#8. 删除刚才的emp_v2 emp_v1

drop view emp_v2,emp_v1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/532901.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

怎样自己开发制作微信小程序?费用多少?

随着移动互联网的深入发展,各行各业都在寻求转型,希望通过线上软件系统来助力传统企业更好的发展,于是各种APP、小程序软件系统层出不穷。微信小程序是诸多软件中最流行的一种,凭借强大的流量基础、随用随走的便捷性和简单易操作的…

【C++】数据结构的恶龙set和map来了~

下一篇AVL树难点中的难点~ 文章目录 前言一、set的介绍二、map的介绍 题目练习总结 前言 1.关联式容器 在初阶阶段,我们已经接触过STL中的部分容器,比如:vector、list、deque、 forward_list(C11)等,这些容器统称为序列式容…

vue3【抛弃vuex,使用pinia】

Pinia Pinia 中文文档 一个全新的用于Vue的状态管理库下一个版本的vuex,也就是vuex5.0vue2 和vue3都支持在vue2中pinia使用vuex的现有接口,所以不能与vuex一起使用相比vuex有更完美的TypeScript支持支持服务器端渲染 Pinia核心概念 Pinia 从使用角度和…

【论文笔记】Learning Latent Dynamics for Planning from Pixels

论文及代码解读:Learning Latent Dynamics for Planning from Pixels 文章目录 论文及代码解读:Learning Latent Dynamics for Planning from Pixels3. Recurrent State Space ModelLatent dynamicsVariational encoderTraining objectiveDeterministic …

Linux系统编程学习 NO.2 ——环境配置和基础指令的学习

操作系统根据使用方式分类 操作系统按照使用类型可分为图形化操作系统和指令操作系统。图形化操作系统的本质其实也是根据指令来操作的。指令更贴近操作系统的底层。而我在学习Linux系统编程时,采用命令行的方式来学习。 补充一个小知识:早期命令行操作…

原装RS罗德与施瓦茨FSW85、FSW50,FSW67信号+频谱分析仪

Rohde & Schwarz FSW85 2Hz至85GHz信号和频谱分析仪 特征 10 kHz 偏移&#xff08;1 GHz 载波&#xff09;时的低相位噪声为 –137 dBc (1 Hz) WCDMA ACLR 测量的 -88 dBc 动态范围&#xff08;带噪声消除&#xff09; 高达 5 GHz 的分析带宽 < 0.4 dB 总测量不确定度高…

投资回报率业内最高!FortiGate在CyberRatings防火墙独立测试中收获近乎完美表现

对于需参考客观产品数据以制定明智采购决策的企业 IT 采购方而言&#xff0c;公正的第三方测试数据不失为一项关键参考。幸运的是&#xff0c;国际第三方安全测评机构CyberRatings始终秉持公平公正的独立测试理念&#xff0c;致力于量化网络安全风险&#xff0c;为多种网络安全…

用gost实现远程端口映射

gost 是一个非常优秀的tunnel. 支持多种形式的端口映射。 本文只介绍远程端口映射方式的tunnel. 远程端口映射的意思就是&#xff0c;将本地端的某个服务的端口A&#xff08;tcp/udp&#xff09;映射到远程的某个端口P上&#xff0c; 用户通过访问远程的端口P来访问本地端的这…

Linux多路转接之poll

文章目录 一、poll的认识二、编写poll方案服务器三、poll方案多路转接的总结 一、poll的认识 多路转接技术是在不断更新进步的&#xff0c;一开始多路转接采用的是select方案&#xff0c;但是select方案存在的缺点比较多&#xff0c;所以在此基础上改进&#xff0c;产生了poll…

怎么缩小照片的kb,压缩照片kb的几种方法

缩小照片的KB大小是我们日常工作生活中遇到的常见问题。虽然听起来十分专业&#xff0c;但其实很简单。照片的KB是指照片文件的大小&#xff0c;通常以“KB”为单位表示。缩小照片的KB就是减小照片文件的大小&#xff0c;以便占用更少的磁盘空间或更快地上传和下载照片。在实际…

什么是BI ?BI 能给企业带来什么价值?

目前&#xff0c;社会数字化程度还在不断加深&#xff0c;数据量也伴随着一同高速增长&#xff0c;许多人预测未来将是数据处理时代&#xff0c;而作为数据类解决方案的商业智能BI也会持续扩张市场&#xff0c;朝着不同行业BI商业智能的方向发展。 利用BI工具系统&#xff0c;…

MySQL 的 varchar 存储原理:InnoDB 记录存储结构

1. InnoDB 是干嘛的&#xff1f; InnoDB 是一个将表中的数据存储到磁盘上的存储引擎。 2. InnoDB 是如何读写数据的&#xff1f; InnoDB 处理数据的过程是发生在内存中的&#xff0c;需要把磁盘中的数据加载到内存中&#xff0c;如果是处理写入或修改请求的话&#xff0c;还…

统计学01: 中心极限定律、正态分布、z-score

<~生~信~交~流~与~合~作~请~关~注~公~众~号生信探索> 中心极限定律 中心极限定律&#xff1a;当样本样足够大时&#xff08;n≥30&#xff09;&#xff0c;样本的mean等于总体的mean 例如&#xff0c;对学校的学生身高抽样&#xff0c;100组每组30人&#xff0c;每组的身…

JavaScript沙箱

1、什么是沙箱 在计算机安全中&#xff0c;沙箱&#xff08;Sandbox&#xff09;是一种用于隔离正在运行程序的安全机制&#xff0c;通常用于执行未经测试或者不受信任的程序或代码&#xff0c;它会为待执行的程序创建一个独立的执行环境&#xff0c;内部程序的执行不会影响到…

【JOSE约瑟 JZS-7E14/11静态可调延时中间继电器 自动控制电路 接通、分断电路】

JZS-7E14/11静态可调延时中间继电器品牌:JOSEF约瑟名称:静态可调延时中间继电器型号:JZS-7E14/11额定电压:6220VDC&#xff1b;6380VAC触点容量:10A/250V10A/220VDC功率消耗:≤6W 一 用途 JZS-7E系列中间继电器用于各种保护和自动控制装置中,以增加保护和控制回路的触点容量. …

Java面试知识点(全)-数据结构和算法

Java面试知识点(全) 导航&#xff1a; https://nanxiang.blog.csdn.net/article/details/130640392 注&#xff1a;随时更新 基础的数据结构 数组 数组的下标寻址十分迅速&#xff0c;但计算机的内存是有限的&#xff0c;故数组的长度也是有限的&#xff0c;实际应用当中的数据…

伙伴云CEO戴志康:低代码与GPT,是赛车手和领航员的角色

GPT来的突然&#xff0c;不仅打了那些对AI冷眼相待的人们一个措手不及&#xff0c;也顺势带动了全民”AIGC”讨论热潮&#xff0c;让大众开始期待它的到来&#xff0c;能为这个人间添上多少精彩.... 万众期待下&#xff0c;GPT也没谦虚&#xff0c;大笔一挥间便融入了到了协同办…

Java集合常见面试题

1、Java集合概述 Java集合&#xff0c;也叫作容器。由两大接口派生而来&#xff1a;Collection接口&#xff0c;用于存放单一元素&#xff1b;Map接口&#xff0c;主要用于存放键值对。对于Collection接口&#xff0c;下面又有三个主要的子接口&#xff1a;List、Set、Queue 2…

桌面远程工具推荐

目前市面上的远程工具多如牛毛&#xff0c;很多人不知道怎么选择&#xff0c;下面小编介绍两种桌面远程工具&#xff0c;它们都是跨平台的&#xff0c;均支持Windows&#xff0c;Mac OS&#xff0c;IOS和安卓&#xff0c;分别是RayLink&#xff0c;VNC&#xff0c;好用&#xf…

eKuiper 源码解读:从一条 SQL 到流处理任务的旅程

概述 LF Edge eKuiper 是 Golang 实现的轻量级物联网边缘分析、流式处理开源软件&#xff0c;可以运行在各类资源受限的边缘设备上。eKuiper 的主要目标是在边缘端提供一个流媒体软件框架。其规则引擎允许用户提供基于SQL 或基于图形&#xff08;类似于 Node-RED&#xff09;的…