가상 테이블은 실제로는 존재하지 않지만(물리적으로는 존재하지 않지만) 논리적으로 존재하는 테이블을 말합니다. MySQL에는 임시 테이블, 메모리 테이블, 뷰의 세 가지 유형의 가상 테이블이 있습니다. select 문에서 반환될 수 있는 유일한 가상 테이블은 뷰와 파생 테이블입니다. 뷰는 여러 테이블 간의 쿼리를 용이하게 하도록 설계되었으므로 뷰는 각 테이블의 관계를 기반으로 여러 테이블의 필드로 생성된 가상 테이블이기도 합니다.
이 튜토리얼의 운영 환경: windows7 시스템, mysql8 버전, Dell G3 컴퓨터.
가상 테이블은 실제로는 존재하지 않지만(물리적으로는 존재하지 않지만) 논리적으로 존재하는 테이블을 말합니다.
MySQL에는 임시 테이블, 메모리 테이블, 뷰, 파생 테이블 등 가상 테이블이 있습니다.
select 문에서 반환할 수 있는 유일한 가상 테이블은 뷰와 파생 테이블입니다.
1. 파생 테이블
Select 문의 from 절에 독립적인 하위 쿼리가 사용되는 경우 이를 파생 테이블이라고 합니다.
与子查询不同,派生表必须具有别名,以便稍后在查询中引用其名字。
如果派生表没有别名,则出错。
二、视图
视图是为了方便多个表联表查询而设计的,所以视图也是多个表中的字段由各个表中的关联关系而创建的一种虚拟表。
视图创建后就保存了下来,以后可以随时用,除非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;
临时表的应用:
注意:
四、内存表
表结构建在磁盘上,数据在内存里,当停止服务后,表中的数据会丢失,而表的结构不会丢失。
内存表也可以被看作是临时表的一种。
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;
内存表特征:
内存表必须使用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 가상 테이블이란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!