MySQL中的临时表与内存表

 更新时间:2024年01月31日 09:37:41   作者:pan_junbiao  
这篇文章主要介绍了MySQL中的临时表与内存表,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

在MySQL中有三种虚拟表:临时表、内存表、视图。下面简单介绍一下临时表和内存表的使用。

1、临时表

MySQL临时表在我们需要保存一些临时数据时是非常有用的。临时表在MySQL 3.23版本中添加。

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

如果你使用了其他MySQL客户端程序连接MySQL数据库服务器来创建临时表,那么只有在关闭客户端程序时才会销毁临时表,当然你也可以手动销毁。

1.1 创建临时表

在MySQL中创建临时表使用CREATE TEMPORARY TABLE语句,其语法格式如下:

CREATE TEMPORARY TABLE [IF NOT EXISTS] 临时表名
(
	...
);

示例:

创建临时表。

CREATE TEMPORARY TABLE IF NOT EXISTS temp_user
(
	id INT NOT NULL DEFAULT 0,
	name VARCHAR(10) NOT NULL
);

还可以通过复制表的方式来创建临时表。

示例:

通过复制表的方式来创建临时表。

CREATE TEMPORARY TABLE temp_user
AS SELECT * FROM tb_user;

1.2 删除临时表

默认情况下,当你断开与数据库的连接后,临时表就会自动被销毁。

当然你也可以在当前MySQL会话中手动删除临时表。

删除临时表与删除普通表的语句是一样的,使用 DROP TABLE语句。

示例:

删除临时表。

DROP TABLE IF EXISTS temp_user;

1.3 使用临时表的注意事项

(1)临时表只在当前连接可见,当这个连接关闭的时候,会自动drop。比如打开mysql 就是一个连接会话。两个不同的连接可以使用相同名字的临时表,两个表之间不存在什么关系,如果临时表的名字和已经存在的磁盘表名字一样,那么临时表会暂时覆盖磁盘表。就是说,你select 查询,只会显示临时表里面的,不会显示磁盘表。

(2)临时表的存储引擎:memor,myisam,merge,innodb,临时表不支持mysql cluster簇。

(3)同一个查询语句,只能用一次临时表,就是说不能将表和自己做连接等。

(4)重命名表,不能用rename 可以用alter table代替。

(5)如果超出了临时表的容量,临时表会转换成磁盘表。

(6)show tables语句不会列出临时表,在information_schema中也不存在临时表信息,show create table可以查看临时表。

2、内存表

内存表的表结构建立在磁盘里面,数据放在内存里面;

当MySQL断开当前连接后,临时表的表结构和表数据都没了,但内存表的表结构和表数据都存在;

当MySQL服务重启之后,内存表的数据会丢失,但表结构依旧存。

2.1 创建内存表

创建内存表与创建普通表一样,使用CREATE TABLE语句,但需要将存储引擎设置为:ENGINE = MEMORY。

其语法格式如下:

CREATE TABLE [IF NOT EXISTS]  内存表名
(
	...
) ENGINE = MEMORY;

示例:

创建内存表。

CREATE TABLE IF NOT EXISTS tmp_table (
	id INT NOT NULL DEFAULT 0,
	name VARCHAR(10) NOT NULL
) ENGINE = MEMORY; 

2.2 删除内存表

删除内存表与删除普通表的语句是一样的,使用 DROP TABLE语句。

示例:

删除内存表。

DROP TABLE IF EXISTS tmp_table;

2.3 使用内存表的注意事项

(1)当MySQL服务重启之后,内存表的数据会丢失,表结构依旧存。

(2)多个session,创建表的名字不能一样。

(3)一个session创建会话后,对其他session也是可见的。

(4)data目录下只有tmp_memory.frm,表结构放在磁盘上,数据放在内存中。

(5)可以创建索引,删除索引,支持唯一索引。

(6)不影响主备,主库上插入的数据,备库也可以查到。

(7)show tables 语句可以查看得到表。

(8)内存表不能包含BLOB或者TEXT列。

(9)内存表支持AUTO_INCREMENT列。

3、临时表与内存表区别

临时表内存表
存储表结构和数据都存储在内存中表结构存储在磁盘中,表数据存储在内存中
会话单个会话独享的,是会话级别的可以多个会话共享
引擎临时表默认,myisam内存表默认,memory
断开连接表结构和表数据都没了表结构和表数据都存在
服务重启表结构和表数据都没了表结构存在,表数据不存在
性能由于表数据都是存放在内存中,所以相对来说,查询速度较快,但是数据的维护较为困难

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Table ‘xxx’ is marked as crashed and should be repaired 错误解决方法参考

    Table ‘xxx’ is marked as crashed and should be repaired 错误解决

    这些东西都是从其他地方找来的一些解决MYSQL数据库这个错误的方法,并不一定适用于神迹数据库,仅仅供参考一下,具体的解决方法还是需要摸索。
    2009-04-04
  • Linux下二进制方式安装mysql5.7版本和系统优化的步骤

    Linux下二进制方式安装mysql5.7版本和系统优化的步骤

    这篇文章主要介绍了Linux下二进制方式安装mysql5.7版本和系统优化的步骤,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • JDBC链接MySQL8的注意事项及说明

    JDBC链接MySQL8的注意事项及说明

    这篇文章主要介绍了JDBC链接MySQL8的注意事项及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Mysql exists用法小结

    Mysql exists用法小结

    这篇文章主要介绍了Mysql exists用法的的相关资料,帮助大家更好的理解和使用MySQL,感兴趣的朋友可以了解下
    2020-12-12
  • MySql事务及ACID实现原理详解

    MySql事务及ACID实现原理详解

    这篇文章主要为大家介绍了MySql事务及ACID实现原理详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • 详细介绍windows下MySQL安装教程

    详细介绍windows下MySQL安装教程

    这篇文章主要给大家介绍的是windows下MySQL安装教程,其实好多公司,数据库的面试题都是不可避免的,甚至一些前端工程师面试的时候都避免不了被询问到和数据库有关的一些问题。下面就从最基础的安装教程开始,需要的朋友可以参考一下
    2021-11-11
  • mysql between实现选取介于两个值之间的数据范围

    mysql between实现选取介于两个值之间的数据范围

    这篇文章主要介绍了mysql between实现选取介于两个值之间的数据范围,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • Mysql锁之共享锁(读锁)和排他锁(写锁)详解

    Mysql锁之共享锁(读锁)和排他锁(写锁)详解

    这篇文章主要介绍了Mysql锁之共享锁(读锁)和排他锁(写锁),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • MySQL索引的一些常见面试题大全(2022年)

    MySQL索引的一些常见面试题大全(2022年)

    索引(Index)是帮助MySQL高效获取数据的数据结构,是对表中一列或多列值进行排序的结构,下面这篇文章主要给大家介绍了关于MySQL索引的一些常见面试题,文中介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • MySql通过ip地址进行访问的方法

    MySql通过ip地址进行访问的方法

    这篇文章主要介绍了MySql通过ip地址进行访问的方法,首先要登录mysql,切换数据库然后授权,具体代码详情大家参考下本文
    2018-06-06

最新评论