Mysql虚表指的是什么意思

71次阅读
没有评论

共计 3827 个字符,预计需要花费 10 分钟才能阅读完成。

这篇文章主要讲解了“Mysql 虚表指的是什么意思”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着丸趣 TV 小编的思路慢慢深入,一起来研究和学习“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 虚表指的是什么意思这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是丸趣 TV,丸趣 TV 小编将为大家推送更多相关知识点的文章,欢迎关注!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-13发表,共计3827字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)