oracle11备份空表,oracle 11g expdp 备份解决空表无法备份

之前做oracle 备份用的都是exp,但exp在11g上存在一个问题,就是无法导出空表。

最近做oracle 数据迁移,需要将空表一同导出,经过搜索,找到了expdb 于是有了此文。

此文仅作记录其中问题,以及我个人对expdp 的理解

在使用expdp impdp之前,需要先建立目录对象,并赋予用户权限。这是因为expdp impdp只能通过DIRECTORY对象关系,将数据存入系统目录。

注:红色部分要替换成实际值

expdp 导出创建DIRECTORY对象和OS PATH映射,并赋予权限

>connect /as sysdba;

>CREATE OR REPLACE DIRECTORY directory_name AS ‘directory_ospath‘;

>GRANT read,write ON DIRECTORY directory_name TOuser_name;

2.查询DIRECTORY

>select * from dba_directories;

>select * from all_directories;

3.expdp 导出

>expdp user_name/user_passwd schemas=user_name dumpfile=expdp.dmp directory=directory_name

schema为数据库对象的集合,一个用户一般对应一个schema,该用户的schema名等于用户名,并作为该用户缺省schema。参考http://blog.csdn.net/kimsoft/article/details/4627520

DIRECTORY             供转储文件和日志文件使用的目录对象。

DUMPFILE              目标转储文件 (expdat.dmp) 的列表

------------------------------------------------------------------------------

ATTACH                连接到现有作业, 例如 ATTACH [=作业名]。

COMPRESSION           减小有效的转储文件内容的大小

关键字值为: (METADATA_ONLY) 和 NONE。

CONTENT               指定要卸载的数据, 其中有效关键字为:

(ALL), DATA_ONLY 和 METADATA_ONLY。

DIRECTORY             供转储文件和日志文件使用的目录对象。

DUMPFILE              目标转储文件 (expdat.dmp) 的列表,

例如 DUMPFILE=scott1.dmp, scott2.dmp, dmpdir:scott3.dmp。

ENCRYPTION_PASSWORD   用于创建加密列数据的口令关键字。

ESTIMATE              计算作业估计值, 其中有效关键字为:

(BLOCKS) 和 STATISTICS。

ESTIMATE_ONLY         在不执行导出的情况下计算作业估计值。

EXCLUDE               排除特定的对象类型, 例如 EXCLUDE=TABLE:EMP。

FILESIZE              以字节为单位指定每个转储文件的大小。

FLASHBACK_SCN         用于将会话快照设置回以前状态的 SCN。

FLASHBACK_TIME        用于获取最接近指定时间的 SCN 的时间。

FULL                  导出整个数据库 (N)。

HELP                  显示帮助消息 (N)。

INCLUDE               包括特定的对象类型, 例如 INCLUDE=TABLE_DATA。

JOB_NAME              要创建的导出作业的名称。

LOGFILE               日志文件名 (export.log)。

NETWORK_LINK          链接到源系统的远程数据库的名称。

NOLOGFILE             不写入日志文件 (N)。

PARALLEL              更改当前作业的活动 worker 的数目。

PARFILE               指定参数文件。

QUERY                 用于导出表的子集的谓词子句。

SAMPLE                要导出的数据的百分比;

SCHEMAS               要导出的方案的列表 (登录方案)。

STATUS                在默认值 (0) 将显示可用时的新状态的情况下,

要监视的频率 (以秒计) 作业状态。

TABLES                标识要导出的表的列表 - 只有一个方案。

TABLESPACES           标识要导出的表空间的列表。

TRANSPORT_FULL_CHECK  验证所有表的存储段 (N)。

TRANSPORT_TABLESPACES 要从中卸载元数据的表空间的列表。

VERSION               要导出的对象的版本, 其中有效关键字为:

(COMPATIBLE), LATEST 或任何有效的数据库版本。

impdp 导入

将expdb 导出的备份文件上传到新库主机

1.将数据导入新库之前,需要新库上创建用户并赋予相关权限

创建用户user_name

$sqlplus sys/ as sysdba;

>CREATE USER user_name IDENTIFIED BY password;

2.赋予user_name用户登录和创建表权限

>GRANT create table,create session TO user_name;

3.分配USERS表配额

sys用户权限:

>GRANT UNLIMITED TABLESPACE TO user_name;

4.创建DIRECTORY对象和OS PATH映射,并赋予权限

>CREATE OR REPLACE DIRECTORY directory_name AS ‘directory_ospath‘;

>GRANT read,write ON DIRECTORY directory_name TOuser_name;

5.导入

>impdp user_name/password directory=directory_name dumpfile=backup_name.dmp schemas=user_name

EXPDP用法举例:

1)按用户导

expdp [email protected] schemas=scott dumpfile=expdp.dmp DIRECTORY=dpdata1;

2)并行进程parallel

expdp [email protected] directory=dpdata1 dumpfile=scott3.dmp parallel=40 job_name=scott3

3)按表名导

expdp [email protected] TABLES=emp,dept dumpfile=expdp.dmp DIRECTORY=dpdata1;

4)按查询条件导

expdp [email protected] directory=dpdata1 dumpfile=expdp.dmp Tables=emp query=‘WHERE deptno=20‘;

5)按表空间导

expdp system/manager DIRECTORY=dpdata1 DUMPFILE=tablespace.dmp TABLESPACES=temp,example;

6)导整个数据库

expdp system/manager DIRECTORY=dpdata1 DUMPFILE=full.dmp FULL=y;

IMPDP用法举例:

1)导到指定用户下

impdp scott/tiger DIRECTORY=dpdata1 DUMPFILE=expdp.dmp SCHEMAS=scott;

2)改变表的owner

impdp system/manager DIRECTORY=dpdata1 DUMPFILE=expdp.dmp TABLES=scott.dept REMAP_SCHEMA=scott:system;

3)导入表空间

impdp system/manager DIRECTORY=dpdata1 DUMPFILE=tablespace.dmp TABLESPACES=example;

4)导入数据库

impdb system/manager DIRECTORY=dump_dir DUMPFILE=full.dmp FULL=y;

5)追加数据

impdp system/manager DIRECTORY=dpdata1 DUMPFILE=expdp.dmp SCHEMAS=system TABLE_EXISTS_ACTION

报错

Q:

ORA-31626: job does not exist

ORA-31687: error creating worker process with worker id 1

ORA-31687: error creating worker process with worker id 1

ORA-31688: Worker process failed during startup.

A:

引用官方Changes

In the first situation AQ_TM_PROCESSES=0

For the second situation AQ_TM_PROCESSES should not be 0.

Cause

For the first situation, AQ_TM_PROCESSES init.ora parameter was set to zero (AQ_TM_PROCESSES=0)

Once removed this parameter from the init.ora file, and bounced the database the problem was resolved

For the second situation, there is likely a lack of memory for the streams_pool_size.

Solution

For the first situation:

o  Remove AQ_TM_PROCESSES init.ora parameter (AQ_TM_PROCESSES=0) from the init.ora.

For the second situation:

o  Allocate between 50-100MB for the STREAMS_POOL_SIZE in order for

datapump to function since it is dependent on streams processing.

简而言之,查询aq_tm_processes值如果为0,则从 init.ora 中将此值删除,然后重启oracle服务

如果为1,则为STREAMS_POOL_SIZE 分配50-100mb 内存

查看aq_tm_processes值

SQL>show parameter process

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

aq_tm_processes                      integer     0

db_writer_processes                  integer     1

gcs_server_processes                 integer     0

job_queue_processes                  integer     10

log_archive_max_processes            integer     2

processes                            integer     150

修改STREAMS_POOL_SIZE

SQL>alter system set streams_pool_size=50m scope=spfile;

Q:

SQL> Connected to an idle instance.

SQL> ORA-01078: failure in processing system parameters

LRM-00109: could not open parameter file ‘/oracle/app/oracle/product/11.2.0/dbhome_1/dbs/initorcl.ora‘

SQL> Disconnected

A:

cp /oracle/app/oracle/admin/orcl/pfile/init.ora.4262015194529 /oracle/app/oracle/product/11.2.0/dbhome_1/dbs/initorcl.ora

当遇到无法启动时,一定要看启动日志的报错信息!

/oracle/app/oracle/product/11.2.0/dbhome_1/startup.log

Q:

ORA-31626: job does not exist

ORA-31633: unable to create master table "SERVER.SYS_IMPORT_FULL_05"

ORA-06512: at "SYS.DBMS_SYS_ERROR", line 95

ORA-06512: at "SYS.KUPV$FT", line 1020

ORA-01031: insufficient privileges

A:

用户没又创建表的权限,给用户creaate table的权限即可

>GRANT CREATE TABLE TO user_name;

Q:

ORA-39006: internal error

ORA-39068: invalid master table data in row with PROCESS_ORDER=-4

ORA-01950: no privileges on tablespace ‘USERS‘

A:

USERS 表空间不足,给用户给USERS 表空间即可

>GRANT UNLIMITED TABLESPACE TO user_name;

或者:

>alter user youruse quota 100m on users;

user_name用户:

> CREATE TABLE test(A varchar2(100));

修改用户密码

ALTER USER user_name IDENTIFIED BY new_password;

删除用户

DROP USER user_name cascade

原文:http://morrowind.blog.51cto.com/1181631/1786008

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值