InterBase数据库迁移到MySQL(恢复备份)

时间:2021-03-07 09:52:57

我拿到的是InterBase导出的“.gbk”后缀的数据库备份文件,目标是可以通过命令行的方式导入到指定的数据库中,在这个脚本中我使用了InterBase数据库中自带的“gbak”命令行来进行操作。

首先来介绍一下这个InterBase数据库吧,http://baike.baidu.com/item/interbase?fr=aladdin——百度百科,大致来说就是一种文件数据库了,而由于我在Ubuntu上找不到对应的安装包,所以就拿InterBase对应的开源版本Firebird数据库来练习了,当然,由于这个程序是在windows平台上运行的,最后的操作我还是在windows7上进行的,只是为了前期的实验方便在Linux上操作了(Linux上包和软件的安装真不是一般的方便额),至于Firebird和InterBase的关系可以看百度百科——http://baike.baidu.com/view/424640.htm?fr=aladdin

InterBase的bin目录下有个gbak程序负责数据库的备份操作。具体的命令如下:

gbak -c -user "sysdba" -password "masterkey" "%path%\dbanme.gbk" "127.0.0.1:%path%\dbanme.gbk'"
gbak <options> -user <username> -password <password> <source> <destination>

在InterBase数据库中默认的用户名是”sysdba”,默认的密码是”masterkey”后面的两个参数分别是要输入的地址,要注意的一点是,第二个参数要在盘符前面加上IP地址,如果是本地的话就是“127.0.0.1”,不加的话会报错。

在安装Firebird的时候会用到gsec命令,gsec是Firebird数据库的用户密码管理工具,要注意的是很有可能在Linux上会发生没有默认用户名密码的情况,如果这样的话就使用修改密码的口令从新修改密码就好了。下面附上程序的代码:

#encoding=utf-8
import os,sys,getopt opts, args = getopt.getopt(sys.argv[1:], "hg:b:",["help","gbk=","gdb="])
input_file=""
output_file=""
def usage():
print """
-h --help print the help
-g --gbk The path of the backup file
-b --gdb Have to backup the database path
"""
for op, value in opts:
if op in ("-g","--gbk"):
input_file = value
elif op in ("-b","--gdb"):
output_file = value
elif op in ("-h","--help"):
usage()
sys.exit() #input_file为要导入的备份文件地址
#output_file为所要恢复的数据库地址
#sysdba为InterBase数据库的默认账户名
#masterkey为InterBase数据库的默认密码 def main():
if os.path.isfile(input_file):
os.system('gbak -c -user "sysdba" -password "masterkey" "'+input_file+'" "127.0.0.1:'+output_file+'"')
else:
print 'Error: File does not exist' if __name__ == '__main__':
main()

InterBase数据库迁移到MySQL(恢复备份)的更多相关文章

  1. InterBase数据库迁移到MySQL(说明)

    刚刚到公司1周便接到了第一个需求,进过了几天的沟通明白了是从gbk文件中恢复InterBase数据库,然后再将恢复到数据库中的数据导出到远程的MySQL数据库中,拿到需求先分步去看问题了,问题大致可分 ...

  2. InterBase数据库迁移到MySQL(数据导出)

    这篇我将记叙我的第二个脚本程序,这篇我使用InterBase数据库提供的“isql”命令来导出我所要的数据,但是由于“isql”命令没有直接导出数据的语句,说以我采用的是导入一个配置文件,在这个文件中 ...

  3. InterBase数据库迁移到MySQL(数据导入)

    在这个脚本中我使用的是Python的ORM框架SQLAlchemy来连接远程的MySQL数据库的,在写这个脚本的时候为了方便参数的输入,我就给之前和这个脚本添加了一个新的功能,就是在调用这个脚本的时候 ...

  4. &lbrack;转载&rsqb;如何将OFBIZ&lpar;opentaps&rpar;默认数据库迁移至mysql&lpar;&lpar;2

    原文地址:如何将OFBIZ(opentaps)默认数据库迁移至mysql(利昂原创)作者:利昂 ofbiz自带的数据库是Derby,这是一种小型的适合与测试系统的数据库,但不适合在产品级系统中使用,所 ...

  5. Oracle 数据库迁移到MySQL &lpar;kettle,navicate,sql developer等工具

    Oracle 数据库迁移到MySQL (kettle,navicate,sql developer等工具 1 kettle --第一次使用kettle玩迁移,有什么不足之处和建议,请大家指正和建议. ...

  6. 从其他数据库迁移到MySQL及MySQL特点

    从其他数据库迁移到MySQL Oracle,SQL Server迁移到MySQL 一些变化 不再使用存储过程.视图.定时作业 表结构变更,如采用自增id做主键,以及其他语法变更 业务SQL改造,不使用 ...

  7. MySQL数据库迁移与MySQL数据库批量恢复

    目录 一.MySQL数据库迁移或备份 1. 了解使用InnoDB引擎创建数据库所产生的文件 2. 迁移数据库步骤 1. 从A服务器迁移至B服务器 2. MySQL重装并导入之前数据库 二.MySQL数 ...

  8. MySQL恢复备份读书笔记

    1. 任何执行时间长于 wait_timeout或interactive_timeout选项值得备份,都会导致会话被关闭,这也会隐含执行UNLOCK TABLES命令.2. 对于使用FLUSH TAB ...

  9. mysql恢复备份导出

    MySQL-5.7 备份与恢复   一.备份分类 按介质分类: 物理备份指通过拷贝数据库文件方式完成备份,适用于数据库很大,数据重要且需要快速恢复的数据库. 逻辑备份指通过备份数据库的逻辑结构和数据内 ...

随机推荐

  1. 基于Netty打造RPC服务器设计经验谈

    自从在园子里,发表了两篇如何基于Netty构建RPC服务器的文章:谈谈如何使用Netty开发实现高性能的RPC服务器.Netty实现高性能RPC服务器优化篇之消息序列化 之后,收到了很多同行.园友们热 ...

  2. python基础整理笔记(八)

    一. python反射的方式来调用方法属性 反射主要指的就是hasattr.getattr.setattr.delattr这四个函数,作用分别是检查是否含有某成员.获取成员.设置成员.删除成员. 此外 ...

  3. Linux之grep命令详解

    简介 grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它 ...

  4. edm注意细节

    Email Direct Marketing不要有js,css也放在html里面不能有热区,所有的border要设置为0在浏览器里面邮件发送可能会歪掉,可以测试接受后是否歪掉 有点时候表格会有细缝等等 ...

  5. BZOJ 1787 紧急集合

    LCA.注意细节. #include<iostream> #include<cstdio> #include<cstring> #include<algori ...

  6. java web 学习十一(使用cookie进行会话管理)

    一.会话的概念 会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话. 有状态会话:一个同学来过教室,下次再来教室,我们会知道这个同学曾 ...

  7. 【Vue 入门】使用 Vue2 开发一个展示项目列表的应用

    前言 一直没有找到一个合适的展示个人项目的模板,所以自己动手使用 Vue 写了一个.该模板基于 Markdown 文件进行配置,只需要按一定规则编写 Markdown 文件,然后使用一个 在线工具 转 ...

  8. 【C&plus;&plus;小白成长撸】--矩阵乘法程序

    矩阵乘法是大学矩阵课程中,相比矩阵加减法比较困难的部分. 矩阵乘法的原理: 矩阵乘法在代码中实现 得到目标矩阵的一个元素,涉及两个求和符号,一个求和符号一个for循环,两个求和符号两个for循环,再加 ...

  9. Javascript--cookie创建与查看

    创建cookie 以下代码将创建一个cookie,该cookie名称为UserName,值为Paul,过期时间为7天后(2015年6月29日) <span style="font-si ...

  10. NLog简单例子

    引用 <?xml version="1.0" encoding="utf-8"?> <packages> <package id= ...