专栏首页码神联盟数据库 | MYSQL 中的视图view详解

数据库 | MYSQL 中的视图view详解

序本文目录

什么是视图

视图的特性

视图的作用

视图使用场景

视图示例1-创建、查询

视图示例2-增、删、改

其它

1什么是视图

视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。

通俗的讲,视图就是一条SELECT语句执行后返回的结果集。所以我们在创建视图的时候,主要的工作就落在创建这条SQL查询语句上。

2视图的特性

视图是对若干张基本表的引用,是一张虚拟表,是查询语句执行的结果,不存储具体的数据(基本表数据发生了改变,视图也会跟着改变),数据还是存储在原来的表里,可以跟基本表一样,进行增删改查操作。

一般来说,我们只是利用视图来查询数据,不会通过视图来操作数据

3视图的作用

(1)选取有用的信息,筛选的作用

视图可以隐藏一些数据

(2)操作简单化,所见即所需

可以展现特定的数据,而无需重复设置查询条件,简化操作。

(3)增加数据的安全性

视图可以只展现数据表的一部分数据,对于我们不希望让用户看到全部数据,只希望用户看到部分数据的时候,可以选择使用视图。

(4)提高逻辑的独立性

当真实的数据表结构发生了变化,可以通过视图来屏蔽真实表的结构变化,从而实现了视图的逻辑独立性。

4视图使用场景

权限控制的时候,不希望用户访问表中某些含敏感信息的列,关键信息来源于多个复杂关联表,可以创建视图提取我们需要的信息,简化操作;

5视图示例1-创建、查询

前期数据准备:

现有三张表:用户(user)、课程(course)、用户课程中间表(user_course),表结构及数据如下:

drop table if exists `course`;

create table `course` (

`id` bigint(20) not null auto_increment,

`name` varchar(200) not null,

`description` varchar(500) not null,

primary key (`id`)

) engine=innodb auto_increment=4 default charset=utf8;

insert into `course` values ('1', 'JAVA', 'JAVA课程');

insert into `course` values ('2', 'C++', 'C++课程');

insert into `course` values ('3', 'C语言', 'C语言课程');

drop table if exists `user`;

create table `user` (

`id` bigint(20) not null auto_increment,

`account` varchar(255) not null,

`name` varchar(255) not null,

`address` varchar(255) default null,

`others` varchar(200) default null,

`others2` varchar(200) default null,

primary key (`id`)

) engine=innodb auto_increment=4 default charset=utf8;

insert into `user` values ('1', 'user1', '小陈', '美国', '1', '1');

insert into `user` values ('2', 'user2', '小张', '日本', '2', '2');

insert into `user` values ('3', 'user3', '小王', '中国', '3', '3');

drop table if exists `user_course`;

create table `user_course` (

`id` bigint(20) not null auto_increment,

`userid` bigint(20) not null,

`courseid` bigint(20) not null,

primary key (`id`)

) engine=innodb auto_increment=7 default charset=utf8;

insert into `user_course` values ('1', '1', '2');

需求场景:获取小张的所有课程信息

思路:

1:之前我们需要些一条sql语句,即可获取

select

uc.id as id, u.name as username, c.name as coursename

from user u

left join user_course uc on u.id = uc.userid

left join course c on uc.courseid = c.id

where u.name = '小张'

2:如果数据量大,且取值复杂,则可以简化,此时,我们需要视图来处理

例如,我们创建视图view_user_course,如下:

drop view if exists view_user_course;

create view view_user_course as (

select

uc.id as id, u.name as username, c.name as coursename

from user u

left join user_course uc on u.id = uc.userid

left join course c on uc.courseid = c.id

);

3:创建好视图之后,我们可以直接用以下SQL语句在视图上查询小张上的所以课程相关信息,同样可以得到所需结果:

select

vuc.username, vuc.coursename

from view_user_course vuc

where vuc.username = '小张'

6视图示例2-增、删、改

继续,我们可以尝试在视图view_user_course上做增删改数据操作,如下:

update view_user_course set username='test',coursename='JAVASCRIPT' where id=3

操作失败,提示错误信息如下:

因为不能在一张由多张关联表连接而成的视图上做同时修改两张表的操作;

那么哪些操作可以在视图上进行呢?

视图与表是一对一关系情况

如果没有其它约束(如视图中没有的字段,在基本表中是必填字段情况), 是可以进行增删改数据操作;

如我们创建用户关键信息视图view_user_keyinfo,如下:

drop view if exists view_user_keyinfo;

create view view_user_keyinfo as

select u.id as id, u.account as account, u.name as username

from user u;

进行增删改操作如下,操作成功(注意user表中的其它字段要允许为空,否则操作失败):

增加:

insert into view_user_keyinfo (account, username) values ('test1', 'test1');

删除:

delete from view_user_keyinfo where username = 'test1';

修改:

update view_user_keyinfo set username = 'user111' where id = 1

视图与表是一对多关系情况

如果只修改一张表的数据,且没有其它约束(如视图中没有的字段,在基本表中是必填字段情况),是可以进行改数据操作,如以下语句,操作成功;

操作之前:

update view_user_course set coursename='JAVA' where id=1;

操作之后:

以下操作失败:

delete from view_user_course where id=3; insert into view_user_course(username, coursename) values('2','3');

7其它

创建视图的时候,也可以增加附加条件,如:

几点说明(MySQL中的视图在标准SQL的基础之上做了扩展):

ALGORITHM=UNDEFINED:指定视图的处理算法;

DEFINER=`root`@`localhost`:指定视图创建者;

SQL SECURITY DEFINER:指定视图查询数据时的安全验证方式;

本文分享自微信公众号 - 码神联盟(lkchatspace),作者:康哥

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2017-10-10

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 珍藏 | Java 岗位 【数据库】 面试题及答案详解

    码神联盟
  • IntelliJ系列 ④ | IDEA 之 Tomcat配置全过程

    码神联盟
  • Shiro系列 | 《Shiro开发详细教程》第三章:Shiro授权流程-下

    subject.checkPermissions("user:update");

    码神联盟
  • MySQL(十一)视图及存储过程

    PS:因为视图不包含数据,所以每次使用视图,都必须处理执行所需的任何一个检索;如果使用了多个联结和过滤创建了复杂的视图或嵌套视图,性能下降比较明显。

    allsmallpig
  • Django 教程 --- Django中的视图

    Django视图是Django M V T结构的重要参与者之一。视图是用户界面,即您呈现网站时在浏览器中看到的内容。它由HTML / CSS / Javascr...

    公众号---人生代码
  • 类视图 vs. 函数视图

    基于类的视图(CBV)和基于函数的视图(FBV)到底有什么区别? 有什么优缺点? 本篇将会去探讨。 在阅读本篇之前,请记住一点「基于类的视图不会替代基于函数的视...

    用户1416054
  • DRF框架(八)——常用功能子类视图 工具视图(继承了GenericAPIView和各种Mixins工具类)

    之前还需要继承多个类,现在将多个类合并为一个,以后只要继承了这一个,那么就相当于继承了多个了。

    一天不写程序难受
  • Django 官方推荐的姿势:类视图

    在开发网站的过程中,有一些视图函数虽然处理的对象不同,但是其大致的代码逻辑是一样的。比如一个博客和一个论坛,通常其首页都是展示一系列的文章列表或者帖子列表。对处...

    HelloGitHub
  • PAMI 2020|基于深度对抗方法处理视图缺失的多视图学习

    今天给大家介绍天津大学张长青老师等人在IEEE T-PAMI 2020上发表的文章“Deep Partial Multi-View Learning”。为了提高...

    智能生信
  • Laravel 视图使用入门

    我们在之前几篇教程中定义的路由大多数返回的都是纯字符串文本或者字符串拼接的 HTML,这主要是为了测试方便,在实际开发中,除了 API 路由返回指定格式数据对象...

    学院君

扫码关注云+社区

领取腾讯云代金券