数据库导库(MySql和Oracle)

Mysql

说明:需要有mysqldump命令

1. 导全量数据

# 登录用户:testuser
# 登录密码:password
# 数据库端口:3306
# 数据库地址:127.0.0.1
# 数据库实例:TESTDB

mysqldump -utestuser -ppassword -h127.0.0.1 -P3306 TESTDB > mysql_dump.sql

# mysql_dump.sql 就是导出的全量sql文件

2. 导指定表:

# tableName 表名
# mysql_dump.sql 导出的sql文件

mysqldump -utestuser -ppassword -h127.0.0.1 -P3306 TESTDB tableName > mysql_dump.sql

3. 指定编码格式导出:

# --default-character-set=gb2312 导出编码格式为gb2312
# tableName 导出表名
# mysql_dump.sql 导出文件

mysqldump -utestuser -ppassword -h127.0.0.1 -P3306 TESTDB --default-character-set=gb2312 tableName > mysql_dump.sql

4. 数据导入新库

# 如果没有实例,则需要新建实例
# 创建新的实例:
# TESTDB 创建的库的名称

# 登录数据库,执行建库语句:
CREATE DATABASE `TESTDB` DEFAULT CHARSET utf8 COLLATE utf8_general_ci;


# 数据库文件导入:
# mysql_dump.sql 需要导入的sql文件
mysql -utestuser -ppassword -h127.0.0.1 -P3306 TESTDB < mysql_dump.sql

5. FAQ

Q:The user specified as a definer (”@’%') does not exist
A:这是因为一些触发器、存储过程等是以之前用户定义的,导入新库之后,用户改变,导致不能正常使用。可以把sql文件中原本用户直接替换为目标用户名
 

sed -i 's/DEFINER=`testuser1`/DEFINER=`testuser2`/g' mysql_dump.sql

Oracle

说明:需要有sqlplus命令

1. 导全量数据:

# testuser 数据库用户名
# password 数据库密码
# 127.0.0.1 数据库地址
# 1521 数据库端口
# TESTDB 数据库实例
# ora.dmp 导出文件名

exp testuser/password@127.0.0.1:1521/TESTDB file=ora.dmp

2. 导指定表:

# tables 需要导的表名列表,多个表名用“,”分割

exp testuser/password@127.0.0.1:1521/TESTDB file=ora.dmp tables=(table1,table2)

3. 数据导入:

# ora.dmp 导入文件名
# testuser2 导入的数据库用户名
# password2 导入的数据库的密码
# 127.0.0.1 导入的数据库的地址
# 1521 导入的数据库的端口
# TESTDB2 导入的数据库的实例

imp testuser2/password2@127.0.0.1:1521/TESTDB2 file=ora.dmp full=y

4. FAQ:

Q:IMP-00013

A:导出数据的用户拥有DBA权限,而要导入的用户没有这个权限
 

# 用sysdba用户给导入用户赋dba权限即可

grant dba to testuser2;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值