mysql复制中临时表的运用技巧

所属分类: 数据库 / Mysql 阅读数: 1075
收藏 0 赞 0 分享
我们知道,临时表有以下特性:
1. SESSION 级别,SESSION 一旦断掉,就被自动DROP 了。
2. 和默认引擎有关。如果默认引擎是INNODB,而你又疯狂的使用临时表。那么,你的IBDATA会被无限的增大。
3. 和磁盘表一样,默认写入到binlog, 而且被动的加入了rollback 计划。

幻想如下场景:
数据库损坏,也没有备份。刚好二进制日志全部保存完好,幸福了。导入二进制日志到MYSQL。

有两种方法:
1) mysqlbinlog ..... *.log | mysql dbname; 这种利用管道直接恢复数据,时间短,效率高。 可里面如果有一堆的临时表,而且刚好在日志的中间,那么悲剧了, 导入失败。 (回想临时表的特性就知道了。)
2) mysqlbinlog ..... *.log > result.log;mysql dbname < result.log; 这种时间长,效率低,占用磁盘空间高,浪费多次系统资源。 可是导入成功了。

如果有大量的临时表应用, 那么在主从复制中,应该采取的正确方法为: (这个我可是08年就说过了。)
在写数据时,当然这里只的是主机。 无论在应用程序或者自己用客户端对MYSQL来进行管理,都应该这样:
复制代码 代码如下:

[sql]
SET SQL_LOG_BIN=0;
关掉SESSION级别的复制。
update tmp_t1, tmp_t2 set ....;
drop tmp_t1;
drop tmp_t2;
SET SQL_LOG_BIN=1;

打开SESSION级别的复制。
更多精彩内容其他人还在看

Mysql select in 按id排序实现方法

有时候我们在后台选择了一系列的id,我们想安装填写id的顺序进行排序,那么就需要下面的order by方法,测试通过
收藏 0 赞 0 分享

mysql 超大数据/表管理技巧

在实际应用中经过存储、优化可以做到在超过9千万数据中的查询响应速度控制在1到20毫秒。看上去是个不错的成绩,不过优化这条路没有终点,当我们的系统有超过几百人、上千人同时使用时,仍然会显的力不从心
收藏 0 赞 0 分享

mysql占用CPU过高的解决办法(添加索引)

下面是MYSQL占用CPU高处理的一个例子,希望对遇到类似问题的朋友们有点启发。一般来说MYQL占用CPU高,多半是数据库查询代码问题,查询数据库过多。所以一方面要精简代码,另一方面最好对频繁使用的代码设置索引
收藏 0 赞 0 分享

MySQL自增列插入0值的解决方案

基于业务逻辑的要求,需要在MySQL的自增列插入0值,针对此需求,本文给予详细的解决方案,感兴趣的你可以参考下哈,希望可以帮助到你
收藏 0 赞 0 分享

Mysql中的find_in_set的使用方法介绍

Mysql中的find_in_set的使用方法介绍,需要的朋友可以参考一下
收藏 0 赞 0 分享

如何用cmd连接Mysql数据库

如何用cmd连接Mysql数据库,需要的朋友可以参考一下
收藏 0 赞 0 分享

SQL字符型字段按数字型字段排序实现方法

由于是按字母顺序排列,所以123排在了2的前面,显然不符合我们的要求,那么怎样才能按照我们预想的数字顺序排序呢
收藏 0 赞 0 分享

服务器不支持 MySql 数据库的解决方法

出现问题:报错“服务器不支持 MySql 数据库”,改函数function_exists('mysql_connect')返回 false
收藏 0 赞 0 分享

MySQL SELECT同时UPDATE同一张表问题发生及解决

例如用统计数据更新表的字段(此时需要用group子句返回统计值),从某一条记录的字段update另一条记录,而不必使用非标准的语句,等等感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

Windows环境下重置mysql密码操作命令

Windows XP系统、xampp集成环境如何重置mysql密码,接下来为大家详细介绍下,感兴趣的各位可以参考下哈,希望可以帮助到你们
收藏 0 赞 0 分享
查看更多