mysql之内存表
一、引言
昨天下午老大让我查资料看一下mysql的内存表在主从备份中是否能被复制,我还没听说过内存表呢,于是上网查资料,记录一下,以便查阅、学习
二、进展
参考:
http://www.cnblogs.com/sunss/p/3191137.html
内存表:
复制代码
session
$ mysql -uroot
root@(none) ::>use test
Database changed
root@test ::>CREATE TABLE tmp_memory (i INT) ENGINE = MEMORY;
Query OK, rows affected (0.00 sec)
root@test ::>insert into tmp_memory values ();
Query OK, row affected (0.00 sec)
root@test ::> session2
$ mysql -uroot test
root@test ::>CREATE TABLE tmp_memory (i INT) ENGINE = MEMORY;
ERROR (42S01): Table 'tmp_memory' already exists
root@test ::>select * from tmp_memory;
+------+
| i |
+------+
| |
+------+
row in set (0.00 sec)
复制代码
. 多个session,创建表的名字不能一样 . 一个session创建会话后,对其他session也是可见的
. data目录下只有tmp_memory.frm ,表结构放在磁盘上,数据放在内存中
. mysql 重启或者关闭后内存表里的数据会丢失,但是表结构仍然存在
. 可以创建索引,删除索引,支持唯一索引
. 不影响主备,主库上插入的数据,备库也可以查到
. show tables 看得到表
http://www.cnblogs.com/sunss/archive/2011/03/16/1986050.html
“内存表”顾名思义创建在内存中的表,真是这样吗?其实不然,MySQL的内存表,表结构创建在磁盘上,数据存放在内存中,所以当MySQL启动着的时候,这个表是存在的,数据也是存在的,如果用户有查看这个表的权限,在所有会话里面,都可以访问这个内存表的数据;当MySQL重启后,数据消失,结构还存在。 内存表的创建: CREATE TABLE test(
id int(),
num int()
) ENGINE=MEMORY DEFAULT CHARSET=utf8;
查看是否创建成功: show tables;
使用完内存表后,如果我们想释放掉占用掉的内存,可以有两种方法:
-- 删除数据
delete from test;
或者 -- 清空表
truncate table test;
再或者
-- 删除表
drop table test;
对于我们常用的功能来说,内存有以下特征: .对于varchar等变长类型,内存表使用固定的长度来存放; .内存表可以有非唯一键; .内存表不能包含BLOB或者TEXT列; .内存表支持AUTO_INCREMENT列; .内存表支持插入延迟,使读取优先; .非临时内存表和其它非内存表一样在所有客户端直接共享; 我们使用内存表的时候,需要注意以下几个方面: .服务器内存足够大; .我们创建的内存表和MySQL内部临时表有所不同: 内存表的数据存放在内存中,而内部临时表(我们的query语句产生的)在恰当的时候存放在内存中,当内部临时表变得很大时,MySQL会自动地把它转化为 在磁盘上存储的表,而我们创建的内存表,却不会自动转换。 .当我们单独地delete from 某个内存表的时候,不会回收内存;只有当整个表被delete的时候,才会回收内存; .在MySQL的主从服务器上,内存表可以被复制
http://dev.mysql.com/doc/refman/5.0/en/memory-storage-engine.html (mysql官方文档,英文不好,参考的不多,英文还需继续努力)
自己的实践--mysql单机
可见执行insert into tblName select * from heapTbl;是可以将数据复制的。
实践--mysql主备--结构:192.168.0.161:2000--192.168.0.161:2001
.在2000节点上创建内存数据库testHeap并插入数据
create table testHeap(i int) type=heap;
在2001节点上show tables是可以看到testHeap的,并且是有数据的。 .在2001节点上对表testHeap插入一些数据
在2000节点上select * from testHeap;是可以看到新数据的。
三、结论
内存表在主从备份结构中是可以被复制的。
mysql之内存表的更多相关文章
- MySQL的内存表(转)
说明:MySQL内存表可以提升一些临时业务的查询,比如做Session的共享,一些类似缓存的数据等. “内存表”顾名思义创建在内存中的表,真是这样吗?其实不然,MySQL的内存表,表结构创建在磁盘上, ...
- mysql的内存表和临时表
内存表: session $ mysql -uroot root@(none) ::>use test Database changed root::>CREATE TABLE tmp_m ...
- 解决mysql的内存表“table is full”错误
最后参考http://blog.sina.com.cn/s/blog_6942a1590101429h.html 来解决,摘录下核心 后来GOOGLE得知,需要重建该表才可以. 1. 设置新的参数 m ...
- 关于mysql内存表的一个帖子(转载)
地址:http://bbs.csdn.net/topics/360030699 引用楼主 zgycsmb 的回复:问:1mysql的内存表性能怎么样2mysql的内存表与system v 这种共享内存 ...
- MySQL内存表-临时表
HEAP表是访问数据速度最快的MySQL表,他使用保存在内存中的散列索引.但如果MySQL或者服务器重新启动,表中数据将会丢失.用法:如论坛的在线人数统计,这种表的数据应该是无关紧要的,就几个简单的字 ...
- MySQL内存表的特性与使用介绍
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- Mysql内存表的用处
文章出自:http://blog.csdn.net/hitzhang/article/details/5994639 个人最欣赏mysql的地方就是他存储引擎的多样性和可扩展性,这样mysql也能拥有 ...
- MySQL内存表的特性与使用介绍 -- 简明现代魔法
MySQL内存表的特性与使用介绍 -- 简明现代魔法 MySQL内存表的特性与使用介绍
- MySQL内存表(MEMORY)说明 | 一个PHP程序员的备忘录
MySQL内存表(MEMORY)说明 | 一个PHP程序员的备忘录 MySQL内存表(MEMORY)说明
随机推荐
- cocos2d-x 3.0 CCTime 的改动
在cocos3.0 中,去掉了CCTimer这个类. 我们须要把之前的代码改动为 定义时间的变量是 struct timeval start 1.获取时间的方式是: gettimeofday(&a ...
- xss学习教程
XSS漏洞详细分析与讲解.rar xss黑白盒渗透测试.pdf xss基础钓鱼-shgcx.com.zip XSS利用教程-shgcx.com.zip xss盲打渗透网站.doc XSS挖掘.ppt ...
- decal in unity
// Upgrade NOTE: commented out 'float4x4 _CameraToWorld', a built-in variable// Upgrade NOTE: replac ...
- Django出现的错误1.TypeError: view must be a callable or a list/tuple in the case of include().1.TypeError: view must be a callable or a list/tuple in the case of include().
.TypeError: view must be a callable or a list/tuple in the case of include(). 原因: url(r"^upload ...
- Linux C高级编程——文件操作之系统调用
Linux C高级编程文件操作之系统调用 宗旨:技术的学习是有限的,分享的精神是无限的. 库函数是一些完毕特定功能的函数.一般由某个标准组织制作公布,并形成一定的标准.使用库函数编 ...
- JMS之——ActiveMQ高可用+负载均衡集群
一.高可用集群 从ActiveMQ5.9开始,ActiveMQ的集群实现方式取消了传统的Master-Slave方式,增加了基于ZooKeeper+LevelDB的Master-Slave实现方式,其 ...
- python——修饰符
修饰符基础--闭包 什么是闭包呢?标准的概念大家可以看wikipedia上的解释 举个例子: def do_add(base): def add(increase): return base + in ...
- UTC时间格式转换
如‘2018-08-07T14:44:40.000+0800’时间转换为正常时间格式 使用moment库 import moment from 'moment' // 日期格式化 formatTime ...
- 关于vector push_back()与其他方式读取数据的效率对比(转)
引言: 在读取大量数据(数组)时,使用vector会尽量保证不会炸空间(MLE),但是相比于scanf的读取方式会慢上不少.但到底效率相差有多大,我们将通过对比测试得到结果. 测试数据:利用srand ...
- static、final修饰符、内部类
static修饰符: static修饰符能够与属性.方法和内部类一起使用,表示静态的.类中的静态变量和静态方法能够与类名一起使用.不须要创建一个类的对象来訪问该类的静态成员. class Static ...