Oracle导出全攻略,零遗漏包括空表

方法一

你可以使用 Oracle 数据泵(Data Pump)工具来导出包括空表在内的数据库对象。

以下是基本的导出命令语法:

ini 复制代码
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,例如:

ini 复制代码
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。

sql 复制代码
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语句,例如:

sql 复制代码
alter table table_name allocate extent;

再用exp导出dmp,就包含全表了。

shell 复制代码
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"
相关推荐
天天要nx2 分钟前
D64【python 接口自动化学习】- python基础之数据库
数据库·python
monkey_meng9 分钟前
【Rust类型驱动开发 Type Driven Development】
开发语言·后端·rust
落落落sss18 分钟前
MQ集群
java·服务器·开发语言·后端·elasticsearch·adb·ruby
精进攻城狮@36 分钟前
Redis(value的数据类型)
数据库·redis
爪哇学长42 分钟前
SQL 注入详解:原理、危害与防范措施
xml·java·数据库·sql·oracle
大鲤余1 小时前
Rust,删除cargo安装的可执行文件
开发语言·后端·rust
她说彩礼65万1 小时前
Asp.NET Core Mvc中一个视图怎么设置多个强数据类型
后端·asp.net·mvc
陈随易1 小时前
农村程序员-关于小孩教育的思考
前端·后端·程序员
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ1 小时前
mybatisPlus打印sql配置
数据库·sql
_江南一点雨1 小时前
SpringBoot 3.3.5 试用CRaC,启动速度提升3到10倍
java·spring boot·后端