首页
学习
活动
专区
圈层
工具
发布

【MySQL】表的内外连接和视图

视图的使用 我们上面所使用的内外连接所生成的表都是一个临时表,假设我们频繁地使用该表,那么有没有办法将这个临时表转化为虚拟表呢? 视图就是一个虚拟表,其内容由查询定义。...同真实的表一样,视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表,基表的数据变化也会影响到视图。...创建视图 create view 视图名 as select语句; 例如我们使用内连接: 而创建视图: 我们会发现多了一个表结构,我们查看该表: 如上,我们发现该表和我们用内连接的结果一样。...修改了视图,对基表数据有影响 修改了基表,对视图有影响 删除视图 drop view 视图名; 2....视图规则和限制 与表一样,必须唯一命名(不能出现同名视图或表名); 创建视图数目无限制,但要考虑复杂查询创建为视图之后的性能影响; 视图不能添加索引,也不能有关联的触发器或者默认值; 视图可以提高安全性

1.1K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL中10多张表关联要做优化,怎么理解逻辑幂等

    最近优化了一条MySQL的慢查询SQL,还是蛮有感触,小结一下。...那就是里面有一个明显全表扫描的逻辑,也就意味着尽管这么多表关联,但是数据量也可以接受,在优化器解析时大部分逻辑是走了索引,优化好最后一个全表扫描,整个问题就迎刃而解了。...整个SQL的逻辑是输出其中product表的数据(字段prod_id,prod_name)和tag表的数据(tag_url),其中表tag和表tag_product)他们通过字段(tag_id)进行关联...,然后和外部的表使用prod_id进行关联,为了体现出是left join(左连接),我把表product的位置及往上放了放。...所以对于上面的逻辑,其实数据表product和表tag要联合输出数据,需要借助一个中间表tag_product,那么tag_product应该是连接数据的纽带,一个相对比较合理的方式就是其实基于表product

    4.2K10

    【MySql】MySql视图

    视图概念 视图就是一张虚拟表,其内容由查询定义。与真实的表一样,视图包含一系列带有名称的列和行数据。视图的数据变化影响到基表,基表的数据变化也会影响到视图。...基表就是数据库中实际存储数据的表,它是视图的数据来源。...select查出来的东西变成了临时表结构,放在表之中,这个表就是视图。...修改视图对基表有影响 举个例子: update myview set ename='smith' where ename='SMITH'; 此时查看基表如下: 修改基表对视图有影响 举个例子:修改基表...的视图 drop view myview; 视图规则和限制 与表一样,必须唯一命名(不能出现同名视图或表名) 创建视图数目无限制,但要考虑复杂查询创建为视图之后的性能影响 视图不能添加索引,也不能有关联的触发器或者默认值

    1.8K20

    MySQL 视图

    数据库视图是虚拟表或逻辑表,它被定义为具有连接的SQL SELECT查询语句。 因为数据库视图与数据库表类似,它由行和列组成,因此可以根据数据库表查询数据。...大多数数据库管理系统(包括MySQL)允许您通过具有一些先决条件的数据库视图来更新基础表中的数据。 数据库视图是动态的,因为它与物理模式无关。...1.视图: 就是一张虚拟表,本质上存储的是一对SQL的集合 --  视图 是一张虚拟的表    01.表示一张表的部分数据或者是多张表的综合数据!   ...04.一个真实的表可以创建N个视图!    05.如果视图关联了多表,不允许增 删!单表可以增删改    06.视图一般都是使用查询!...`studentNo` --  查询视图中的内容 SELECT * FROM view_student_result -- 查询mysql数据库中所有的视图 SELECT * FROM information_schema.views

    4.2K110

    MySQL视图

    1.概念 MySQL 视图(View)是一种虚拟存在的表,同真实表一样,视图也由列和行构成,但视图并不实际存在于数据库中。...视图并不同于数据表,它们的区别在于以下几点: 视图不是数据库中真实的表,而是一张虚拟表,其结构和数据是建立在对数据中真实表的查询基础上的。...从安全的角度来看,视图的数据安全性更高,使用视图的用户不接触数据表,不知道表结构。 视图的建立和删除只影响视图本身,不影响对应的基本表。...视图定义后,编写完所需的查询,可以方便地重用该视图。 要注意区别视图和数据表的本质,即视图是基于真实表的一张虚拟的表,其数据来源均建立在真实表的基础上。...MySQL 可以在单个数据表上创建视图。

    6.3K10

    【MySQL】--- 视图

    一、视图的本质:虚拟的表,动态的数据 视图的核心定义可以概括为:视图是一个虚拟的表,它基于一个或多个基本表(或其他视图)的查询结果集。...与物理表不同,视图本身并不存储实际数据,它更像是一个“查询语句的封装器”——当用户访问视图时,数据库会动态执行其底层的查询语句,从基础表中获取最新数据并返回。...这一特性带来了几个关键结论: 视图不占用物理存储空间(仅存储定义信息) 视图的数据完全依赖于基础表,基础表数据变化会实时反映到视图中 对视图的合法修改也会同步影响基础表(存在一定限制) 形象地说,视图就像数据库中的...视图与表的联合查询 视图还可以与其他表或视图进行联合查询,进一步扩展查询能力: -- 视图与基础表联合查询 SELECT vs.student_name, vs.course_name,...即修改基础表的数据会影响视图,修改视图的数据(在允许的情况下)也会影响基础表。 1.

    10410

    MySQL 视图

    看到这里,或许你已经对MySQL 的基本操作了如指掌,这篇文章讲解MySQL高级功能中 视图的概念及其用法。 什么是视图 ( view ) ?...视图,即虚拟表,通过底层接口封装的 SQL 语句查询到的内容作为虚拟表中的数据,因此视图中的记录来自数据表,它本身不存储数据。...把经常查询的结果集放到虚拟表中,提升使用效率 CREATE VIEW 视图名 AS SELECT 字段1,字段2 FROM 表 where 条件; #当视图创建之后,它就相当于一个虚拟表,可以直接使用...视图名; #结果:字段1(字段2) 视图的优点 安全性:虚拟表是基于底层数据表的,我们在使用视图时,一般不会轻易通过视图对底层数据进行修改 简单清晰:视图是对 SQL 查询的封装,它可以将原本复杂的...另外,我们也需要了解到视图是虚拟表,本身不存储数据,如果想要通过视图对底层数据表的数据进行修改也会受到很多限制,通常我们是把视图用于查询。

    3.8K20

    MySQL 视图

    ​看到这里,或许你已经对MySQL 的基本操作了如指掌,这篇文章讲解MySQL高级功能中 视图的概念及其用法。 什么是视图 ( view ) ?...视图,即虚拟表,通过底层接口封装的 SQL 语句查询到的内容作为虚拟表中的数据,因此视图中的记录来自数据表,它本身不存储数据。...视图可以连接一个或多个数据表的部分字段,也可以针对不同的用户创建不同的查询视图。 视图的地位 如何创建视图 ?...把经常查询的结果集放到虚拟表中,提升使用效率 CREATE VIEW 视图名 ASSELECT 字段1,字段2 FROM 表 where 条件;​#当视图创建之后,它就相当于一个虚拟表,可以直接使用:SELECT...另外,我们也需要了解到视图是虚拟表,本身不存储数据,如果想要通过视图对底层数据表的数据进行修改也会受到很多限制,通常我们是把视图用于查询。

    3.9K40

    【MySQL】视图

    一、什么是视图 ✨1.概念 视图是一种虚拟的表,他是基于一个或者多个基本表或者其他视图的查询结果集。视图本身是不存在的,而是通过执行查询来动态生成数据。...✨2.特点 虚拟性:视图就像一个虚拟的表,他在数据库中只存储了定义视图的查询语句,不存储实际的数据。数据仍然存储在原始的表中,视图只是提供了一种访问数据的方式。...二、视图的使用 ✨1.视图的创建 语法 create view 视图名称[(自定义列名)] as 查询结果; 示例 -- 查询班级表中的信息 mysql> select * from class; +...如果表中有重复的列名,那么就会创建失败 -- 将查询两个表中班级相对应的相关信息直接创建成一个视图,可以直接查询 mysql> create view v_students_class as select...:自定义视图列名,可以解决表中出现重复列名的情况 mysql> create view v1_srudents_class(class,id,name,class_name) as select s.class_id

    36410

    MySQL视图

    视图是关系型数据库重要的组成部分之一,它可以限制数据访问,简化复杂查询,保持数据的独立性,以及基于相同的数据提供不同的视图等等。本文介绍MySQL数据库视图的一些用法,供大家参考。...一、视图的特点 image.png 视图与表类似,包含列和数据行 可以对视图查询或特定情形下DML操作 视图仅仅包含一些DDL定义语句 视图不存储任何真实数据,数据来源于基表 视图限制访问数据...二、简单视图特点 单表查询 不包含相关聚合函数 不包含分组 可通过DML语句更新视图 --1、 请创建一个视图返回更新日期为大于2016-02-15之后客户信息 -- 当前版本 mysql...,名称为vw_inventory CREATE OR REPLACE VIEW vw_inventory AS SELECT * FROM vw_inve; 三、复杂视图的特点 基于多个表连接查询或者子查询...-- 查看视图 mysql> show full tables mysql> show full tables like '%vw%'; -- 提取视图DDL mysql> show create

    4K20

    MySQL视图

    一.视图的概念 视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表,基表的数据变化也会影响到视图。 注:基表就是我们创建的表。...准备工作 以员工表和部门表作为基表: 将其机进行内连接,并筛选ename和dname字段: 我们如果想高频的取查询一条数据中的ename和dname,每次都进行内连接会很麻烦,因此我们可以将上图中最下面的查询结果当做一张视图...修改视图 update myview set ename='smith' where ename='SMITCH'; 修改视图也会影响原始数据,即影响基表: 反过来也一样,修改基表也会影响视图,实际上视图与基表是连通的...删除视图 drop view myview; 上述表中,删除了myview表。 三.视图的规则和限制 与表一样,必须唯一命名(不能出现同名视图或表名)。...order by 可以用在视图中,但是如果从该视图检索数据 select 中也含有 order by ,那么该视图中的 order by 将被覆盖。 视图可以和表一起使用。

    1.1K30

    MySQL视图

    视图是指计算机数据库中的视图,是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。...行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。 一、视图概述 1.1、什么是视图 在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表。...视图包含行和列,就像一个真实的表。视图中的字段就是来自一个或多个数据库中的真实的表中的字段。...视图名 as select 字段名 from 表名; 案例: 创建一个视图 mysql> create view s_view as (select sname,sex,age from students...视图名  as  select 字段名 from 表名; 3.2、select 语句 修改 案例: 修改我们的s_view视图 mysql> alter view s_view as select sname

    8.7K20

    mysql视图

    一、视图概念   数据库中的视图是一个虚拟表。同真实的表一样,视图包含系系列带有名称的行和列数据。行和列数据来自于由定义视图查询所引用的表,并且在引用视图时动态生成。...五、修改视图   修改视图是指修改数据库中存在的视图,当基本表的某些字段发生变化的时候,可以通过修改视图保持与基本表的一致性。...Mysql中通过create or replace view语句和alter语句来修改视图 1、使用create or replace view语句修改视图 首先通过desc查看修改之前的视图,方便比较...,因为视图是一个虚拟表,所以其中没有数据。...通过视图更新的时候都是转到基本表上进行更新的,对视图增加或者删除记录,实际上是对其基本表增加或者删除记录。

    3.4K40

    事务、视图、锁表

    普通的MySQL执行语句后,当前的数据提交操作均可被其他客户端可见。 而事务是暂时关闭“自动提交”机制,需要commit提交持久化数据操作。 -- 注意 1....(针 对当前事务) 5.什么是视图 (1)视图是一张虚拟表 表示一张表的部分数据或多张表的综合数据 其结构和数据是建立在对表的查询基础上 (2)视图中不存放数据 数据存放在视图所引用的原始表中 (3...)一个原始表,根据不同用户的不同需求,可以创建不同的视图 6.视图的用途 筛选表中的行 防止未经许可的用户访问敏感数据 降低数据库的复杂程度 将多个物理数据库抽象为一个逻辑数据库 7.如何创建视图 (1...;//删除前判断视图是否存在 (3)使用SQL语句查看视图 SELECT 字段1, 字段2, …… FROM view_name; 8.使用视图注意事项 视图中可以使用多个表 一个视图可以嵌套另一个视图...对视图数据进行添加、更新和删除操作直接影响所引用表中的数据 当视图数据来自多个表时,不允许添加和删除数据,一个表时可以进行修改 5.查看所有视图 USE information_schema; SELECT

    98620

    Mysql视图

    1.初识视图 1.视图的概念和作用 什么是视图:是从一个或多个表中导出来的表,它是一种虚拟存在的表,表的结构和数据都依赖于基本表。 作用: 简化查询语句:简化用户的查询操作,使查询更加快捷。...例如,当基本表中的某些字段发生变化时,视图必须修改才能正常使用。...使用INSERT语句通过视图向基本表添加数据 #创建视图 mysql> CREATE VIEW view_ category AS -> SELECT id, name FROM sh_goods_category...; 2.修改数据 使用UPDATE语句通过视图修改基本表中的数据 #修改数据 mysql> UPDATE view_category SET name = '家电' WHERE id = 17; Query...FROM sh_ goods_ category WHERE id = 17; 3.修改数据 使用DELETE语句通过视图删除基本表中的数据 #删除数据 mysql> DELETE FROM view_category

    3.4K10
    领券