`
youyu4
  • 浏览: 435714 次
社区版块
存档分类
最新评论

MySQL内存表与临时表

 
阅读更多

MySQL内存表与临时表

 

内存表

 

session 1
$ mysql -uroot
root@(none) 10:05:06>use test
Database changed
root@test 10:06:06>CREATE TABLE tmp_memory (i INT) ENGINE = MEMORY;
Query OK, 0 rows affected (0.00 sec)
root@test 10:08:46>insert into tmp_memory values (1);
Query OK, 1 row affected (0.00 sec)
root@test 10:08:46>

session2
$ mysql -uroot test
root@test 10:05:12>CREATE TABLE tmp_memory (i INT) ENGINE = MEMORY;
ERROR 1050 (42S01): Table 'tmp_memory' already exists
root@test 10:16:27>select * from tmp_memory;
+------+
| i |
+------+
| 1 |
+------+
row in set (0.00 sec)

 

 

1. 多个session,创建表的名字不能一样

2. 一个session创建会话后,对其他session也是可见的

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

4. mysql 重启或者关闭后内存表里的数据会丢失,但是表结构仍然存在

5. 可以创建索引,删除索引,支持唯一索引

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

7. show tables 看得到表

 

 

临时表

 

session1
$ mysql -uroot test
root@test 10:30:18>CREATE TEMPORARY TABLE tmp_table (name VARCHAR(10) NOT NULL,value INTEGER NOT NULL);
Query OK, 0 rows affected (0.05 sec)
root@test 10:31:54>select * from tmp_table;
+--------+-------+
| name | value |
+--------+-------+
| aaaaaa | 10 |
+--------+-------+
row in set (0.00 sec)

session2
root@test 10:20:13> CREATE TEMPORARY TABLE tmp_table (name VARCHAR(10) NOT NULL,value INTEGER NOT NULL);
Query OK, 0 rows affected (0.02 sec)

root@test 10:30:39>insert into tmp_table values ('bbbbbbb',10);
Query OK, 1 row affected (0.01 sec)

root@test 10:31:33>select * from tmp_table;
+---------+-------+
| name | value |
+---------+-------+
| bbbbbbb | 10 |
+---------+-------+
row in set (0.00 sec)

root@test 10:31:43>exit
Bye
[1 Single:MS-Master db152011.sqa.cm6: mysql ~ ]
$ mysql -uroot test
root@test 10:32:17>select * from tmp_table;
ERROR 1146 (42S02): Table 'test.tmp_table' doesn't exist
root@test 10:32:22>
root@test 10:32:23>

 

 

1. 创建的表的名字可以一样 

2. 表结构和数据都放在内存中

3. 会话消失表结构和数据都消失

4. 可以创建索引,删除索引

5. 主库创建的表,备库查不到,

6. show tables 看不到表

 

 

使用内存表需要注意的事项

1. 内存表需要自己delete数据或者drop表;需要drop权限,这点比较危险

2. 内存表的表结构是保存在磁盘上的,如果多个session使用同一个表名,会存在冲突;如果不需要使用表名,如果使用一次都需要创建表结构,到时候会有很多小文件存在,不利于db的维护,dba清理表也有风险;

 

 

基于以上不适合用内存表

1. 临时表是会话级别的,即使多个session创建的表名一样,都相互不影响

2. 会话消失,所有的都消失,这点很不利于应用排查问题

 

另外这两个都需要消耗额外的内存空间,虽然db端可以忍受,但是不太可控;DB端还有这个参数:

max_tmp_tables 一个客户能同时保持打开的临时表的最大数量,这个值默认32,可以根据需要调整此值

 

 

参考:

http://www.cnblogs.com/sunss/archive/2013/07/15/3191137.html

分享到:
评论

相关推荐

    Mysql临时表和派生表

    ### MySQL临时表与派生表详解 #### 一、MySQL临时表 **1.1 临时表概述** MySQL中的临时表是一种特殊的表类型,主要用于存储临时数据或中间结果集,适用于那些需要多次查询同一结果集的场景。根据存储位置的不同,...

    MySQL性能分析之临时表

    #### 一、临时表与磁盘临时表 在MySQL数据库管理系统中,**临时表**是一种特殊类型的表,主要用于存储中间结果集,它可以帮助执行一些复杂的查询操作,如`GROUP BY`、`DISTINCT`、某些`ORDER BY`以及`UNION`等操作...

    Mysql临时表使用说明

    #### 临时表与内存存储 为了进一步提高性能,可以将临时表设置为HEAP类型,即在内存中存储数据。HEAP表(在MySQL中已替换为MEMORY引擎)通过在RAM中存储数据而非磁盘,显著提升了读写速度。创建内存存储的临时表...

    MYSQL 临时表用法总结

    磁盘临时表与普通表类似,其数据存储在物理磁盘上。创建示例: ```sql CREATE TEMPORARY TABLE test_table_20200313 ( commandid bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT 'id', idcid varchar(18) ...

    MySQL内存表的特性与使用介绍

    如果数据超出这个限制,系统会报错,而不是自动转为磁盘表,与临时表的行为不同。 3. **重启行为**:内存表的表结构是持久化的,存储在`.frm`文件中,因此重启MySQL服务不会丢失表定义。然而,表中的数据是存储在...

    浅谈MySQL临时表与派生表

    如果内存临时表的大小超过系统变量`max_heap_table_size`和`tmp_table_size`设置的较小值,数据将被写入磁盘上的MyISAM引擎表,即变为磁盘临时表。临时表在用户断开与MySQL服务器的连接后会被自动删除,释放占用的...

    MySQL中的两种临时表

    HEAP表的数据完全存储在内存中,无须磁盘IO,而OnDisk临时表则将数据存储在磁盘上,用于处理较大的中间结果。当HEAP表超过`MAX_HEAP_TABLE_SIZE`限制时,它会自动转为OnDisk表。在MySQL 5.7中,OnDisk临时表的存储...

    Mysql临时表原理及创建方法解析

    4. **潜在风险**:如果临时表与永久表具有相同的名称,可能会在重连后造成混淆,导致误操作永久表中的数据。为避免这种情况,可以使用`DROP TEMPORARY TABLE`语句来删除临时表,而不是`DROP TABLE`。 临时表的主要...

    MySQL8.0内存相关参数总结

    这些参数控制着不同操作的内存使用,如排序、连接、读取和临时表。根据工作负载的特点,可以适当调整它们以优化性能,例如,处理大量JOIN操作时,增大`join_buffer_size`可能有所帮助。 在调整这些参数时,需要...

    MySQL临时表的简单用法介绍

    然而,内存临时表有一些限制,如大小限制和数据丢失风险(如果服务器崩溃或断电)。因此,使用HEAP表时需要谨慎,确保数据量不会过大,并考虑备份或持久化策略。 临时表在多种场景下都非常有用,比如: 1. 当你需要...

    MySQL临时表空间优化:提升数据库性能的关键

    1. **内存临时表**:这类表存储在内存中,访问速度非常快,但受限于系统的可用内存空间。 2. **磁盘临时表**:这类表存储在磁盘上,虽然存储空间相对较大,但访问速度较慢。 #### 优化临时表空间的步骤 1. **确定...

    深度解析MySQL 5.7之临时表空间

    在MySQL里面这种临时表对应的是内存表,即memory引擎。 2、会话级别临时表 这种临时表在用户登录系统成功后生效,在用户退出时失效。在MySQL里的临时表指的就是以create temporary table 这样的关键词创建的表。 3...

    解析Mysql临时表及特点

    总结来说,Mysql的临时表和内存表在存储数据时有着本质上的区别。临时表是完全基于内存的,没有持久化的数据文件;而内存表则是基于内存的存储引擎,数据也是存储在内存中,但表结构保存在磁盘上。临时表适合解决...

    MySql内存数据库.pdf

    `:创建一个新的数据表,TEMPORARY表示临时表,IF NOT EXISTS用于避免创建重复的表。create_definition定义表中的列,table_options定义表的一些属性,select_statement用于根据已有的表创建新表。 - `SHOW COLUMNS ...

    MySQL问答系列之什么情况下会用到临时表

    临时表分为内存临时表和磁盘临时表,前者使用memory存储引擎,后者通常使用myisam(在MySQL 5.7.6之前)或innodb(5.7.6之后,默认存储引擎可通过`internal_tmp_disk_storage_engine`参数设置)存储引擎。...

    MySQL优化中的内存计算公式

    ### MySQL优化中的内存计算公式详解 ...通过对MySQL内存计算公式的理解与应用,不仅可以有效控制内存使用,还能确保数据库在高负载下稳定运行。希望本文能为您的MySQL优化工作提供一定的参考价值。

Global site tag (gtag.js) - Google Analytics