iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Mysql虚表指的是什么意思
  • 353
分享到

Mysql虚表指的是什么意思

mysql 2023-05-25 13:05:31 353人浏览 泡泡鱼
摘要

这篇文章主要讲解了“Mysql虚表指的是什么意思”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql虚表指的是什么意思”吧!

这篇文章主要讲解了“Mysql虚表指的是什么意思”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql虚表指的是什么意思”吧!

虚拟表是实际上并不存在(物理上不存在),但是逻辑上存在的表。在mysql中,存在三种虚拟表:临时表、内存表和视图;而只能从select语句可以返回虚拟表的是视图和派生表。视图是为了方便多个表联表查询而设计的,所以视图也是多个表中的字段由各个表中的关联关系而创建的一种虚拟表。

虚拟表,就是实际上并不存在(物理上不存在),但是逻辑上存在的表。

在MySQL中,存在的虚拟表:临时表、内存表和视图,派生表。

只能从select语句可以返回虚拟表的是视图和派生表。

一、派生表

当select语句的from子句中使用独立子查询时,就称其为派生表。

select column_list
from (
      select column_list
      from table_1
      ) derived_table_name
where derived_table_name.c1 > 0 ;

与子查询不同,派生表必须具有别名,以便稍后在查询中引用其名字。

如果派生表没有别名,则出错。

二、视图

视图是为了方便多个表联表查询而设计的,所以视图也是多个表中的字段由各个表中的关联关系而创建的一种虚拟表。

视图创建后就保存了下来,以后可以随时用,除非drop删除视图。

数据库中,只存放了视图的定义,并没有存放视图的数据,数据还是存储在原来的表中,

视图的数据是依赖原来表中的数据的,所以原来表的数据发生了改变,那么显示的视图的数据也会随着改变。

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

1.创建视图

-- other
create view other as 
select a.name as username, b.name as Goodsname from 
user as a, goods as b where a.id=b.id;

2.删除视图

drop view if exists other;

3.调用视图

select * from other;

4.如果视图不存在,则创建视图;如果视图存在,则修改视图

create or replace view view_name as select 语句;

视图创建一遍后会在navicat premium(MySQL可视化工具)保存下来,不可重复创建视图,

所以想重复调试创建视图,需先删除已创建的视图,在执行创建视图的SQL命令或者是修改视图。

视图作用:

  • 提高了重用性,就项一个函数,创建一次,可重复调用。

  • 数据库重构,却不影响原数据。

  • 让数据更加清晰。想要什么样的数据,就创建什么样的视图。

视图定义的存放位置:infORMation_schema.views

查看视图的基本信息:DESC view_name;

注意:

  • 修改视图的数据,将直接修改数据表(即原表)的真实数据。

  • 删除视图,不会影响原表的数据,但是删除视图的数据,则会影响到原表。

即可以从select语句可以返回虚拟表,又可以通过构建表结构创建虚拟表的是临时表和内存表。

三、临时表

MySQL临时表在保存一些临时数据时是非常有用的。

临时表是建立在系统临时文件夹中的表,使用得当,完全可以像普通表一样进行各种操作。

临时表的数据和表结构都存储在内存中。

临时表只在当前MySQL连接可见,当关闭连接时,MySQL会自动删除表并释放所有空间。

1.通过构建临时表结构创建临时表

create temporary table tmp_table (
name VARCHAR(10) NOT NULL,
value INTEGER NOT NULL
);

select * from tmp_table;

2.直接将查询结果导入临时表

create temporary table tmp_table select * from other;

3.删除临时表

drop table tmp_table;

临时表的应用:

  • 当某一个SQL语句关联的表在2张及以上,并且和一些小表关联。可以采用将大表进行拆分并且得到比较小的结果集合存放在临时表中。

  • 程序执行过程中可能需要存放一些临时数据,这些数据在整个程序的会话过程中需要重复使用。

  • 临时表默认是MyISAM(存储引擎),但是可以修改。

注意:

  • 临时表与存在的表名相同的时候,存在的表会被隐藏,当临时表被drop,存在的表就可见了。

  • show tables语句不会列举临时表,但是会列出内存表。

  • 临时表在数据库多个连接之间不能共享。

  • 临时表的最大所需内存需要通过tmp_table_size=128MB设定。当数据超过临时表的最大值设定时,自动转为磁盘表,此时因需要进行IO操作,性能会大大下降,而内存表不会,内存表满后,会提示数据满错误。

  • 临时表更多作用是系统自己创建或,组织数据以提升性能,如子查询。

四、内存表

表结构建在磁盘上,数据在内存里,当停止服务后,表中的数据会丢失,而表的结构不会丢失。

内存表也可以被看作是临时表的一种。

1.通过构建内存表结构创建内存表

create table tmp_table (
name VARCHAR(10) NOT NULL,
value INTEGER NOT NULL
)ENGINE=MEMORY;

select * from tmp_table;
show tables;

2.直接将查询结果导入内存表

create table tmp_table engine=memory 
  select * from other;

3.释放占用的内存

-- 删除数据
delete from tmp_table;
-- 清空表
truncate table tmp_table;
-- 删除表
drop table tmp_table;

内存表特征:

  • 对于varchar等变长类型,内存表使用固定的长度来存放。

  • 内存表可以有非唯一的键。

  • 内存表不能包含BLOB或TEXT列。

  • 内存表支持AUTO_INCREMENT列。

  • 内存表支持插入延迟,使读取优先。

  • 当临时表变得很大时,MySQL会自动地把它转化为在磁盘上存储的表,而内存表不会自动转换。

  • 在MySQL的主从服务器上,内存表可以被复制。

  • 内存表最大的size受限于系统变量max_heap_table_size,默认值是16MB,这个变量是可以修改的。

  • 内存表对所有用户的连接都是可见的,使得它非常适合做缓存

  • 内存表必须使用memory存储引擎。

内存表的注意事项:

1、heap不允许使用xxxTEXT和xxxBLOB数据类型;只允许使用=和<=>操作符来搜索记录(不允 许& amp; lt;、>、<=或>=);mysql4.1版本之前不支持auto_increment;只允许对非空数据列进行索引(not null)。

注:操作符 “<=>” 说明:NULL-safe equal.这个操作符和“=”操作符执行相同的比较操作,不过在两个操作码均为NULL时,其所得值为1而不为NULL,而当一个操作码为NULL时,其所得值为0而不为NULL。

2、内存表可以通过max_heap_table_size = 2048M来加大使用的内存。

3、内存表必须使用memory存储引擎

五、临时内存表

1.通过构建表结构创建临时内存表

create temporary table tmp_table (
name VARCHAR(10) NOT NULL,
value INTEGER NOT NULL
)ENGINE=MEMORY;

select * from tmp_table;
show tables;

2.直接将查询结果导入内存表

create temporary table tmp_table engine=memory 
  select * from other;

临时表使用注意事项:

(1)临时表只在当前连接可见,当这个连接关闭的时候,会自动drop。这就意味着你可以在两个不同的连接里使用相同的临时表名,并且相互不会冲突,或者使用已经存在的表,但不是临时表的表名。(当这个临时表存在的时候,存在的表被隐藏了,如果临时表被drop,存在的表就可见了)。

(2)临时表只能用在 memory,myisam,merge,或者innodb引擎。

(3)临时表不支持mysql cluster(簇)。

(4)在同一个query语句中,你只能查找一次临时表。例如:下面的就不可用

  mysql> SELECT * FROM temp_table, temp_table AS t2;
  ERROR 1137: Can't reopen table: 'temp_table'

  如果在一个存储函数里,你用不同的别名查找一个临时表多次,或者在这个存储函数里用不同的语句查找,这个错误都会发生。

(5)show tables 语句不会列举临时表,但是会列出内存表。

(6)你不能用rename来重命名一个临时表。但是,你可以alter table代替:

mysql>ALTER TABLE orig_name RENAME new_name;

感谢各位的阅读,以上就是“Mysql虚表指的是什么意思”的内容了,经过本文的学习后,相信大家对Mysql虚表指的是什么意思这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

您可能感兴趣的文档:

--结束END--

本文标题: Mysql虚表指的是什么意思

本文链接: https://www.lsjlt.com/news/218261.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mysql虚表指的是什么意思
    这篇文章主要讲解了“Mysql虚表指的是什么意思”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql虚表指的是什么意思”吧! ...
    99+
    2023-05-25
    mysql
  • mysql指的是什么意思
    这篇文章给大家分享的是有关mysql指的是什么意思的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。mysql是关系型数据库管理系统的缩写,即MySQL是一个关系型数据库管理系统,由...
    99+
    2022-10-18
  • mysql ddl指的是什么意思
    小编给大家分享一下mysql ddl指的是什么意思,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!mysql ddl是数据定于语言的缩写,简单来说,就是对数据库内部的对象进行创建、删除、修改等操...
    99+
    2022-10-18
  • mysql root指的是什么意思
    这篇文章主要介绍mysql root指的是什么意思,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! root指的是超级管理员;MySQL在安装时,会默认创建...
    99+
    2022-10-19
  • mysql索引指的是什么意思
    这篇文章主要介绍了mysql索引指的是什么意思,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。MySQL官方对索引的定义为:索引(Index)是帮...
    99+
    2022-10-18
  • mysql中shell指的是什么意思
    这篇文章给大家分享的是有关mysql中shell指的是什么意思的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。MySQL Shell是在官方版本5.7.12推出,工具的初衷本身都是...
    99+
    2022-10-18
  • mysql中and指的是什么意思
    这篇文章主要介绍mysql中and指的是什么意思,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 在mysql中,and的意思为“并且”,用于在WHER&#...
    99+
    2022-10-19
  • Navicat for MySQL指的是什么意思
    小编给大家分享一下Navicat for MySQL指的是什么意思,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!  Navica...
    99+
    2022-10-18
  • 手机虚拟机指的是什么意思
    这篇文章给大家分享的是有关手机虚拟机指的是什么意思的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。手机虚拟机一般指的是java虚拟机,因为手机上的程序都是用java编写的;而java程序都是在java虚拟机里运行的...
    99+
    2023-06-06
  • html中表单指的是什么意思
    这篇文章给大家分享的是有关html中表单指的是什么意思的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 在html中,表单是一个包含表单元素的区域,主要...
    99+
    2022-10-19
  • MySQL中join buffer指的是什么意思
    小编给大家分享一下MySQL中join buffer指的是什么意思,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、说明在MySQL对于join操作的处理过程中,...
    99+
    2023-06-15
  • 在mysql中mul指的是什么意思
    这篇文章主要介绍了在mysql中mul指的是什么意思,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。在mysql中mul是Key,而key是键的意...
    99+
    2022-10-18
  • mysql中大表是什么意思
    这篇文章主要介绍mysql中大表是什么意思,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!前言相对来说,什么情况下的数据库表能够称为“大表”呢?当一个表的数据超过千万行的时候,就会对数...
    99+
    2022-10-18
  • mysql存储过程指的是什么意思
    小编给大家分享一下mysql存储过程指的是什么意思,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、说明一组预先编译好的SQL语句的集合,理解成批处理语句。可以提...
    99+
    2023-06-15
  • mysql复合主键指的是什么意思
    本篇内容介绍了“mysql复合主键指的是什么意思”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2023-04-03
    mysql
  • mysql安全模式指的是什么意思
    小编给大家分享一下mysql安全模式指的是什么意思,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!什么是安全模式?mysql安全模...
    99+
    2022-10-18
  • JVM指的是什么意思
    这篇文章将为大家详细讲解有关JVM指的是什么意思,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Java虚拟机(JVM)是可运行Java代码的假想计算机。只要根据JVM规格描述将解释器移植到特定的计算机上,...
    99+
    2023-06-03
  • xps指的是什么意思
    小编给大家分享一下xps指的是什么意思,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!xps是XML Paper Specification即XML文件规格书的简称...
    99+
    2023-06-06
  • chrome指的是什么意思
    这篇文章主要介绍了chrome指的是什么意思,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。chrome是Google公司开发的一款网页浏览器。Chrome在设计术语中的意思是...
    99+
    2023-06-08
  • ide指的是什么意思
    这篇文章将为大家详细讲解有关ide指的是什么意思,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。ide全称“Integrated Development Environment”,中文意思为“集成开发环境”...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作