Oracle导出全攻略,零遗漏包括空表 |
您所在的位置:网站首页 › exp导出部分表部分数据 › Oracle导出全攻略,零遗漏包括空表 |
方法一
你可以使用 Oracle 数据泵(Data Pump)工具来导出包括空表在内的数据库对象。 以下是基本的导出命令语法: expdp username/password@connect_string DIRECTORY=data_pump_dir DUMPFILE=filename.dmp SCHEMAS=schema_name其中,username 是具有 EXP_FULL_DATABASE 权限的用户,password 是该用户的密码,connect_string 是连接数据库的字符串,DIRECTORY 是导出文件存储的目录名称,DUMPFILE 是导出文件名称,SCHEMAS 是需要导出的模式名称。 如果要同时导出空表,可以添加参数 CONTENT=ALL,例如: expdp username/password@connect_string DIRECTORY=data_pump_dir DUMPFILE=filename.dmp SCHEMAS=schema_name CONTENT=ALL这样将会导出指定模式下的所有对象,包括空表。 方法二使用Oracle 11g的exp命令导出用户数据库表的时候,有的rows为0的空表不能导出,原因是Oracle 11g新增了一个特性,deferred_segment_creation,其含义是段延迟创建,默认参数为true。 当新建数据表且参数为true时,没有向其中插入数据,那么这个表不会立即分配segment,也就是不占数据空间,即表不分配segment以节省空间,所以这些表也没能导出来。 在系统表user_tables中也可以看到segment_treated的字段里是“NO”或者“YES”说明了该表是否分配了segment。 select 'alter table ' ||table_name ||' allocate extent;' from user_tables where segment_created='NO'; -- 或者 select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0 or num_rows is null;执行生成的sql语句,例如: alter table table_name allocate extent;再用exp导出dmp,就包含全表了。 rem windows环境下Oracle数据库的自动备份脚本。 rem 可以将本批处理设成windows任务计划下自动执行。 @echo off @echo ================================================ @echo windows环境下Oracle数据库的自动备份脚本 @echo 说明:启动备份时,需要配置以下变量 @echo 1、BACKUP_DIR 指定要备份到哪个目录 @echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名 @echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码 @echo 4、ORACLE_DB 指定备份所用的Oracle连接名 @echo 5、BACK_OPTION 备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 等等.... @echo 6、RAR_CMD 指定RAR命令行压缩工具所在目录 @echo ================================================ rem 以下变量需要根据实际情况配置------> 注意:此脚本必须放在d:\backup目录下 set BACKUP_DIR=D:\backupyy set ORACLE_USERNAME=test set ORACLE_PASSWORD=test set ORACLE_DB=orcl set BACK_OPTION=owner=test set RAR_CMD="C:\Program Files\WinRAR\Rar.exe" rem 开始备份 exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file=%BACKUP_DIR%\%date:~0,4%-%date:~5,2%-%date:~8,2%.dmp log=%BACKUP_DIR%\%date:~0,4%-%date:~5,2%-%date:~8,2%.log rem 压缩并删除原有文件 %RAR_CMD% a -df "%BACKUP_DIR%\%date:~0,4%-%date:~5,2%-%date:~8,2%.rar" "%BACKUP_DIR%\%date:~0,4%-%date:~5,2%-%date:~8,2%.dmp" "%BACKUP_DIR%\%date:~0,4%-%date:~5,2%-%date:~8,2%.log" |
今日新闻 |
点击排行 |
|
推荐新闻 |
图片新闻 |
|
专题文章 |
CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭 |