如何把MYSQL数据库改为ORACLE

如何把MYSQL数据库改为ORACLE,第1张

1修改数据库连接字符串:

如:

驱动器commysqljdbcDriver 改为 oraclejdbcdriverOracleDriver

连接字符串jdbc:mysql://localhost:3306/xxx 改为 jdbc:oracle:thin:@localhost:1521:sid

2调整SQL语句:

如:

分页查询SELECT FROM TABLE_NAME LIMIT 1, 20 改为 SELECT FROM (SELECT A, ROWNUM RN FROM (SELECT FROM TABLE_NAME) A WHERE ROWNUM <= 20) WHERE RN >= 1

3将mysql库中的数据导入到oracle库:

可以手工进行,如将mysql中的数据转储为sql文,作下调整,在oracle中执行;

建议使用相关工具,如Oracle SQL Developer。

4将连接数据库的jar包换成oracle的。

MySQL 在崩溃恢复时,会遍历打开所有 ibd 文件的 header page 验证数据字典的准确性,如果 MySQL 中包含了大量表,这个校验过程就会比较耗时。 MySQL 下崩溃恢复确实和表数量有关,表总数越大,崩溃恢复时间越长。另外磁盘 IOPS 也会影响崩溃恢复时间,像这里开发库的 HDD IOPS 较低,因此面对大量的表空间,校验速度就非常缓慢。另外一个发现,MySQL 8 下正常启用时居然也会进行表空间校验,而故障恢复时则会额外再进行一次表空间校验,等于校验了 2 遍。不过 MySQL 80 里多了一个特性,即表数量超过 5W 时,会启用多线程扫描,加快表空间校验过程。

如何跳过校验MySQL 57 下有方法可以跳过崩溃恢复时的表空间校验过程嘛?查阅了资料,方法主要有两种:

1 配置 innodb_force_recovery可以使 srv_force_recovery != 0 ,那么 validate = false,即可以跳过表空间校验。实际测试的时候设置 innodb_force_recovery =1,也就是强制恢复跳过坏页,就可以跳过校验,然后重启就是正常启动了。通过这种临时方式可以避免崩溃恢复后非常耗时的表空间校验过程,快速启动 MySQL,个人目前暂时未发现有什么隐患。2 使用共享表空间替代独立表空间这样就不需要打开 N 个 ibd 文件了,只需要打开一个 ibdata 文件即可,大大节省了校验时间。自从听了姜老师讲过使用共享表空间替代独立表空间解决 drop 大表时性能抖动的原理后,感觉共享表空间在很多业务环境下,反而更有优势。

临时冒出另外一种解决想法,即用 GDB 调试崩溃恢复,通过临时修改 validate 变量值让 MySQL 跳过表空间验证过程,然后让 MySQL 正常关闭,重新启动就可以正常启动了。但是实际测试发现,如果以 debug 模式运行,确实可以临时修改 validate 变量,跳过表空间验证过程,但是 debug 模式下代码运行效率大打折扣,反而耗时更长。而以非 debug 模式运行,则无法修改 validate 变量,想法破灭。

这个,你确定保存数据文件的目录下没有“巴依托海乡frm”这个文件吗?

嗯,我没有碰到这种情况,另外我的汉语表名存储的都是@632这种文件名,只能对你碰到的情况提这个比较基础的建议,还有同情

MySQL在51引入了一个rename

database *** 作,但在MySQL5123后又不支持这个命令。可以说是一个实验性的功能,没有在生产中支持过(mysql-51

release在mysql-5130),那么生产中我们有时为了追求完美需要改一下库名。怎么 *** 作呢?

这里提供一个变通的方法。

1

创建出新库名:

复制代码

代码如下:

mysql>create

database

db_v2;

2生成rename语句,从olddb里迁移,我这里olddb里sbtest;

复制代码

代码如下:mysql>select

concat("rename

table

",table_schema,"",table_name,"

to

db_v2",table_name,";")

into

outfile

'/tmp/rename_to_db_v2sql'

from

information_schematables

where

table_schema='sbtest';

3执行生成的sql

复制代码

代码如下:mysql>source

/tmp/rename_to_db_v2sql

就这么简单可以搞定了。

Good

luck!

以上就是关于如何把MYSQL数据库改为ORACLE全部的内容,包括:如何把MYSQL数据库改为ORACLE、系统崩溃后,关于MYSQL恢复数据库的问题!求救啊!、关于Mysql 表名不能重命名的问题等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9273064.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存