温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MySQL视图的概念

发布时间:2021-08-30 18:33:21 来源:亿速云 阅读:127 作者:chen 栏目:数据库

本篇内容主要讲解“MySQL视图的概念”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL视图的概念”吧!

1、基本概念

  视图本身是一张虚拟表,不存放任何数据。在使用SQL语句访问视图的时候,获取的数据是MySQL从其它表中生成的,视图和表在同一个命名空间。视图查询数据相对安全,视可以隐藏一些数据和结构,只让用户看见权限内的数据,使复杂的查询易于理解和使用。

2、视图用法

  现在基于用户和订单管理演示视图的基本用法。

  基础表结构

  基本语法

  CREATEORREPLACEVIEWview_name

  ASselect_statement

  注意事项:表和视图共享数据库中相同的名称空间,因此,数据库不能包含具有相同名称的表和视图。

  用户订单视图

  CREATEORREPLACE

  VIEWuser_order_viewASSELECT

  t1.id,t1.user_name,t2.order_no,t2.good_id,

  t2.good_name,t2.num,t2.total_price

  FROMv01_usert1

  LEFTJOINv02_ordert2ONt2.user_id=t1.id;

  视图调用

  这里和MySQL的表查询基本一致,可以使用各种查询条件。

视图实现

  临时表算法

  服务器会把视图查询SQL的数据保存在临时表中,临时表的结构和视图字段结构一致,这样是SQL查询优化中最忌讳的操作,数据量稍微偏大,就会严重影响性能。如果视图无法和原有表产生一对一的映射关系,就会产生临时表,由此也可见视图并不是很简单,甚至是非常复杂的功能。

  合并算法

  服务器基于视图中使用的表执行查询,最后把查询结构合并后返回给客户端。

  区别方法

  执行如下查询语句,可以分析执行的性能参数。

  EXPLAINSELECT*FROMuser_order_view;

  观察查询结果中select_type字段,如果是DERIVED则说明使用临时表。这里SQL执行分析的语法后面优化部分再详解。

到此,相信大家对“MySQL视图的概念”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI