本文介绍: 如果我们定义视图时,如果指定条件然后我们插入修改删除数据时,是否可以做到必须满足条件才能操作,否则不能够操作呢?视图中的数据并不在数据库中实际存在行和列数据来自定义视图查询使用的表,并且是在使用视图动态生成的。查询每个学生所选修的课程三张表联查),这个功能在很多的业务中都有使用到,为了简化操作,定义一个视图。上述的视图中,就只有一个单行单列的数据,如果我们对这个视图进行更新插入的,将会报错。会通过视图检查正在更改的每个行,例如 插入更新删除,以使其符合视图的定义。

♥️作者:小刘在C站

♥️个人主页 小刘主页 

♥️努力不一定有回报,但一定会有收获加油!一起努力,共赴美好人生!

♥️学习两年总结出的运维经验,以及思科模拟器全套网络实验教程专栏云计算技术

♥️小刘私信可以随便问,只要会绝不吝啬,感谢CSDN让你我相遇!

前言

本章讲解SQL语言视图,为上章。

目录

1 视图

1.1 介绍

1.2 语法

1). 创建

2). 查询

3). 修改

4). 删除

1.3 检查选项

1). CASCADED

 2). LOCAL

 1.4 视图的更新

 1.5 视图作用

1). 简单

2). 安全

3). 数据独立

1.6 案例


1 视图

1.1 介绍

视图(
View
)是一种虚拟存在的表。视图中的数据并不在数据库中实际存在行和列数据来自定义视图的查询中使用的表,并且是在使用视图时动态生成的。
通俗的讲,视图只保存查询
SQL
逻辑,不保存查询结果。所以我们在创建视图的时候,主要的工作就落在创建这条
SQL
查询语句上。

1.2 语法

1). 创建

CREATE [OR REPLACE] VIEW 视图名称[(列名列表)] AS SELECT语句 [ WITH [
CASCADED | LOCAL ] CHECK OPTION ]

2). 查询

查看创建视图语句:SHOW CREATE VIEW 视图名称;
查看视图数据:SELECT * FROM 视图名称 ...... ;

3). 修改

方式一:CREATE [OR REPLACE] VIEW 视图名称[(列名列表)] AS SELECT语句 [ WITH
[ CASCADED | LOCAL ] CHECK OPTION ]
方式二:ALTER VIEW 视图名称[(列名列表)] AS SELECT语句 [ WITH [ CASCADED |
LOCAL ] CHECK OPTION ] 

4). 删除

DROP VIEW [IF EXISTS] 视图名称 [,视图名称] ...
-- 创建视图
create or replace view stu_v_1 as select id,name from student where id <= 10;


-- 查询视图

show create view stu_v_1;
select * from stu_v_1;
select * from stu_v_1 where id < 3;


-- 修改视图
create or replace view stu_v_1 as select id,name,no from student where id <= 10;
alter view stu_v_1 as select id,name from student where id <= 10;


-- 删除视图
drop view if exists stu_v_1;
上述我们演示了,视图应该如何创建、查询、修改、删除,那么我们能不能通过视图来插入更新数据呢? 接下来,做一个测试
create or replace view stu_v_1 as select id,name from student where id <= 10 ;

select * from stu_v_1;

insert into stu_v_1 values(6,'Tom');

insert into stu_v_1 values(17,'Tom22');
执行上述的
SQL
,我们会发现
id

6

17
的数据都是可以成功插入的。 但是我们执行查询,查询出来的数据,却没有
id

17
记录

因为我们在创建视图的时候指定条件
id<=10, id

17
的数据,是不符合条件的,所以没有查
询出来,但是这条数据确实是已经成功的插入到了基表中
如果我们定义视图时,如果指定条件然后我们在插入、修改、删除数据时,是否可以做到必须满足条件才能操作,否则不能够操作呢? 答案是可以的,这就需要借助于视图的检查选项了。

1.3 检查选项

当使用
WITH CHECK OPTION
子句创建视图时,
MySQL
通过视图检查正在更改的每个行,例如 插入,更新,删除,以使其符合视图的定义。
MySQL
允许基于一个视图创建视图,它还会检查依赖
图中的规则以保持一致性。为了确定检查的范围
mysql
提供了两个选项
CASCADED

LOCAL
默认值
CASCADED

1). CASCADED

级联。
比如
v2
图是基于
v1
视图的,如果在
v2
视图创建时候指定了检查选项
cascaded
,但是
v1
视图创建时未指定检查选项。 则在执行检查时,不仅会检查
v2
,还会级联检查
v2
关联视图
v1

 2). LOCAL

本地
比如
v2
图是基于
v1
视图的,如果在
v2
视图创建的时候指定了检查选项
local
,但是
v1
视图创
建时未指定检查选项。 则在执行检查时,知会检查
v2
,不会检查
v2
关联视图
v1

 1.4 视图的更新

要使视图可更新,视图中的行与基础表中的行之间必须存在一对一的关系。如果视图包含以下任何一项,则该视图不可更新:
A.
聚合函数窗口函数
SUM()

MIN()

MAX()

COUNT()
等)
B. DISTINCT
C. GROUP BY
D. HAVING
E. UNION
或者
UNION ALL
create view stu_v_count as select count(*) from student;
上述的视图中,就只有一个单行单列的数据,如果我们对这个视图进行更新或插入的,将会报错。
insert into stu_v_count values(10);

 1.5 视图作用

1). 简单

视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件

2). 安全

数据库可以授权,但不能授权到数据库特定行和特定的列上。通过视图用户只能查询和修改他们所能见到的数据

3). 数据独立

视图可帮助用户屏蔽真实表结构变化带来的影响

1.6 案例

1).
为了保证数据库表的安全性开发人员在操作
tb_user
表时,只能看到用户基本字段屏蔽
create view tb_user_view as select id,name,profession,age,gender,status,createtime
from tb_user;
select * from tb_user_view;
2).
查询每个学生所选修的课程三张表联查),这个功能在很多的业务中都有使用到,为了简化操作,定义一个视图。
create view tb_stu_course_view as select s.name student_name , s.no student_no ,
c.name course_name from student s, student_course sc , course c where s.id =
sc.studentid and sc.courseid = c.id;
select * from tb_stu_course_view;

♥️关注,就是我创作的动力

♥️点赞,就是对我最大的认可

♥️这里是小刘,励志用心做好每一篇文章,谢谢大家

原文地址:https://blog.csdn.net/lzl10211345/article/details/131193767

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_25792.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注