通过Oracle来辅助MySQL数据问题的恢复
MySQL中的数据量相对来说还不是很大,所以可以考虑多个MySQL database和一个Oracle中的多个schema映射起来,数据类型可以适当做一
今天琢磨一个问题,在平时的工作中如果碰到一些不规范的操作,drop,truncate,delete,恢复起来还是很困难的,drop操作在Oracle中如果开启了recycle bin还是基本安全的,delete操作可以借助flashback delete操作,可能有些更细微的操作update,insert等等操作导致了问题,,需要做数据修复的时候,这个时候可以使用flashback query来辅助,如果来一个truncate,那就没辙了,其实在truncate操作完成后,一般来说数据还都是在数据文件里的,这个时候可以借助第三方的数据恢复工具来尝试恢复,这个时候数据恢复就不是毫秒级了,容忍度在分钟甚至小时都是没有办法的事情。
不过在Oracle中,如果你之前开启了闪回数据库功能,那truncate的数据就能找回来了。但是话说过来,整个系统都让重启给弄停了,这个影响可能更大。如果不使用flashback database,直接通过dataguard来做时间点恢复或者其它的标准恢复到数据删除之前,也是一种方法。
所以说在Oracle中对于数据的恢复方法很多,使用场景也可以根据需要来选择。
在MySQL中数据恢复可供选择的方案相对就比较少了。不过有一个亮点就是MySQL中的redo日志是可读的,mysqlbinlog可以很轻松地解析出来里面的内容。不过truncate,drop,一些DML失误操作场景来说,对于MySQL来说就比较困难了。
一旦发生了问题,做数据的恢复就只能借助于最近的备份了,需要相应的备份,然后在最近的备份基础上通过解析相关的binlog,直到把数据变更时间点的数据恢复。
这个过程总体来说还是需要不少的时间的,首先就是判断备份和binlog的时间点,可以在其它测试环境中完成,需要花费的时间应该不短。
我想了下面这个方案,把Oracle和mysql结合起来,充分利用Oracle的强大的闪回功能,可能这种方案对于很多数据恢复都有不少的亮点。
还没有在本地测试,因为也需要一些额外的定制和数据类型映射,所以只是一个大概的思路。
首先还是保持MySQL原有的架构,一个主库,两个备库。因为主库中的binlog是做数据同步的关键,所以可以考虑设置一个路径做sql解析,sql解析还是使用binlog,然后再做适当的变更。这个过程可以是一个异步的过程,然后和Oracle结合起来部署到Oracle中的schema中。
MySQL中的数据量相对来说还不是很大,所以可以考虑多个MySQL database和一个Oracle中的多个schema映射起来,数据类型可以适当做一些类型映射,比如,MySQL中的big int,small int等和Oracle中的number直接映射。varchar和varchar2映射等等。
数据到位之后,就可以考虑通过各种闪回特性来做数据的恢复了。发生了truncate之类的操作可以使用flashback database来恢复,drop操作可以通过recycle bin,flashback database或者基于时间点等来恢复。delete可以通过闪回删除,闪回查询等来恢复。update可以通过闪回查询来恢复等等。得到了相应的技术局之后,可以直接导出csv文件,或者insert语句来。在MySQL中通过mysqlimport或者insert来完成数据的部署。
这个过程中可以使得MySQL端始终保持前行,可以打一个比方,比如一个部队在行军,结果突然某个军官发现自己的地图没带,落下半路上了,这个时候可以派一个士兵骑马去取地图。这个时候Oracle就是那个士兵,能够完成这个艰巨的任务,部队依旧行进,不会产生其他影响。
本文永久更新链接地址:

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

全表扫描在MySQL中可能比使用索引更快,具体情况包括:1)数据量较小时;2)查询返回大量数据时;3)索引列不具备高选择性时;4)复杂查询时。通过分析查询计划、优化索引、避免过度索引和定期维护表,可以在实际应用中做出最优选择。

InnoDB的全文搜索功能非常强大,能够显着提高数据库查询效率和处理大量文本数据的能力。 1)InnoDB通过倒排索引实现全文搜索,支持基本和高级搜索查询。 2)使用MATCH和AGAINST关键字进行搜索,支持布尔模式和短语搜索。 3)优化方法包括使用分词技术、定期重建索引和调整缓存大小,以提升性能和准确性。

是的,可以在 Windows 7 上安装 MySQL,虽然微软已停止支持 Windows 7,但 MySQL 仍兼容它。不过,安装过程中需要注意以下几点:下载适用于 Windows 的 MySQL 安装程序。选择合适的 MySQL 版本(社区版或企业版)。安装过程中选择适当的安装目录和字符集。设置 root 用户密码,并妥善保管。连接数据库进行测试。注意 Windows 7 上的兼容性问题和安全性问题,建议升级到受支持的操作系统。

聚集索引和非聚集索引的区别在于:1.聚集索引将数据行存储在索引结构中,适合按主键查询和范围查询。2.非聚集索引存储索引键值和数据行的指针,适用于非主键列查询。

MySQL是一个开源的关系型数据库管理系统。1)创建数据库和表:使用CREATEDATABASE和CREATETABLE命令。2)基本操作:INSERT、UPDATE、DELETE和SELECT。3)高级操作:JOIN、子查询和事务处理。4)调试技巧:检查语法、数据类型和权限。5)优化建议:使用索引、避免SELECT*和使用事务。

MySQL支持四种索引类型:B-Tree、Hash、Full-text和Spatial。1.B-Tree索引适用于等值查找、范围查询和排序。2.Hash索引适用于等值查找,但不支持范围查询和排序。3.Full-text索引用于全文搜索,适合处理大量文本数据。4.Spatial索引用于地理空间数据查询,适用于GIS应用。

MySQL 数据库中,用户和数据库的关系通过权限和表定义。用户拥有用户名和密码,用于访问数据库。权限通过 GRANT 命令授予,而表由 CREATE TABLE 命令创建。要建立用户和数据库之间的关系,需创建数据库、创建用户,然后授予权限。

MySQL 和 MariaDB 可以共存,但需要谨慎配置。关键在于为每个数据库分配不同的端口号和数据目录,并调整内存分配和缓存大小等参数。连接池、应用程序配置和版本差异也需要考虑,需要仔细测试和规划以避免陷阱。在资源有限的情况下,同时运行两个数据库可能会导致性能问题。
