数据库备份

1、通过命令行实现

数据导出:

exp test/test@192.168.110.228:1521/orcl file=E:\1\test.dmp
数据导入:
imp test/test@192.168.110.228:1521/orcl file=E:\1\test.dmp full=y;
只导表不导数据:
exp test/test@192.168.110.228:1521/orcl file=D:\test.dmp rows=n 

但是此方法在导出表的时候导不出空表,

2、解决办法

 1、先查询一下当前用户下的所有空表 
 select table_name from user_tables where NUM_ROWS=0; 
    2、用以下这句查找空表 

      select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0 

       把查询结果导出,执行导出的语句 

      'ALTERTABLE'||TABLE_NAME||'ALLOCATEEXTENT;' 
      ----------------------------------------------------------- 
      alter table AQ$_AQ$_MEM_MC_H allocate extent; 

      alter table AQ$_AQ$_MEM_MC_G allocate extent; 

      alter table AQ$_AQ$_MEM_MC_I allocate extent; 

      alter table AQ$_AQ_PROP_TABLE_T allocate extent; 

      alter table AQ$_AQ_PROP_TABLE_H allocate extent; 

      alter table AQ$_AQ_PROP_TABLE_G allocate extent; 

      alter table AQ$_AQ_PROP_TABLE_I allocate extent; 

      alter table AQ$_KUPC$DATAPUMP_QUETAB_T allocate extent; 

      alter table AQ$_KUPC$DATAPUMP_QUETAB_H allocate extent; 

      alter table AQ$_KUPC$DATAPUMP_QUETAB_G allocate extent; 

      alter table AQ$_KUPC$DATAPUMP_QUETAB_I allocate extent; 
    3、然后再执行    
exp 用户名/密码@数据库名 file=/home/oracle/exp.dmp log=/home/oracle/exp_smsrun.log   成功! 
ORACLE 11G在用EXPORT导出时,空表不能导出。 
11G中有个新特性,当表无数据时,不分配segment,以节省空间 
  解决方法: 
  1、insert一行,再rollback就产生segment了。 
  该方法是在在空表中插入数据,再删除,则产生segment。导出时则可导出空表。 
  2、设置deferred_segment_creation 参数 
  该参数值默认是TRUE,当改为FALSE时,无论是空表还是非空表,都分配segment。 

  需注意的是:该值设置后对以前已经存在的空表不产生作用,仍不能导出,只能对后面新增的表产生作用。如需导出之前的空表,只能用第一种方法】 
觉得不是解决方法,然后就用了expdp和impdp 
create directory expdp_dir as   '/data/app1/dp'; 
grant read,write on directory expdp_dir to DRGN_OWNER; 

expdp DRGN_OWNER/DRGN_OWNER DIRECTORY=expdp_dir DUMPFILE=DRGN_OWNER.dmp SCHEMAS=DRGN_OWNER logfile=DRGN_OWNERexpdp.log 

create directory impdp_dir as '/data/app1/dp'; 
grant read,write on directory impdp_dir to DRGN_OWNER; 

impdp DRGN_OWNER/DRGN_OWNER DIRECTORY=impdp_dir DUMPFILE=DRGN_OWNER.dmp logfile=DRGN_OWNER.dmpimpdp.log 

空表果然已经导入了 

对于DBA新建数据库,我个人建议,建立了空的数据库后,马上执行 
alter system set deferred_segment_creation=flase sscope=spfile; 
shutdowm immediate 
startup 



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值