小景的Dba之路--如何导出0记录表以及数据泵的使用
小景最近在系统压测相关的工作,其中涉及了数据备份导出的操作。今天的问题是:exp命令不会导出0记录表,那么我们探讨下如何导出0记录表以及数据泵的使用。
首先,我们先刨析一下问题现象及原因:
在 Oracle 中,使用传统的 `exp` 命令进行导出通常不会导出0记录的表,即那些不包含任何数据的表。这是因为 `exp` 命令默认情况下只导出包含数据的表和其他对象。
当使用 `exp` 命令时,它会生成一个包含导出的表结构和数据的数据泵文件(通常以 `.dmp` 扩展名结尾)。如果表是空的,它将不会包含在导出文件中。
这一行为在某种程度上是出于效率考虑,因为导出0记录表通常没有多大意义,而且它们可以在需要时轻松重新创建。
那么我们讨论下解决方案:
1. 手动创建DDL脚本:使用SQL工具,手动编写表的DDL脚本,包括表的结构、索引、约束等信息。然后将这个DDL脚本保存到一个SQL文件中,以备将来使用。
2. 使用数据泵工具(expdp):Oracle数据泵工具(`expdp`)允许你更灵活地定义导出的内容。你可以使用数据泵来导出表结构,而无需导出数据。以下是一个示例:
expdp username/password@db_name DIRECTORY=dpump_dir DUMPFILE=table_structure.dmp CONTENT=METADATA_ONLY TABLES=your_table
这将导出名为 `your_table` 的表的结构到一个 `.dmp` 文件中。
3. 使用Oracle SQL Developer:如果你使用 Oracle SQL Developer 工具,你可以使用其导出功能,它允许你选择要导出的对象,包括表结构。
有了解决方案,下面就详细说下各个解决方案的具体操作:
1.针对手动创建DDL脚本:
1. 登录到数据库:使用具有足够权限的数据库用户账号登录到数据库,以执行DDL操作。
2. 选择要导出的表:确定你要导出结构的表名称。
3. 生成DDL脚本:使用SQL工具(如SQL*Plus或SQL Developer)执行以下SQL查询,以生成DDL脚本:
-- 生成表的DDL脚本
DESC your_table;
上述查询会返回表 `your_table` 的结构信息,包括列名、数据类型、约束等。你可以将这些信息复制到一个SQL文件中。或者,你也可以使用以下查询来生成表的DDL脚本文件:
-- 生成表的DDL脚本到文件
SET PAGESIZE 0
SET LONG 90000
SET LINESIZE 1000
SPOOL table_structure.sql
SELECT DBMS_METADATA.GET_DDL('TABLE', 'YOUR_TABLE') FROM DUAL;
SPOOL OFF
这将生成一个名为 `table_structure.sql` 的SQL文件,其中包含表 `your_table` 的DDL。
4. 保存DDL脚本:将生成的DDL脚本保存到一个SQL文件中,以备将来使用。
现在,你有了一个包含所选表结构的DDL脚本文件。你可以在需要时使用此文件来重新创建表结构或将它部署到其他数据库中。
需要注意的是,这个DDL脚本只包含表的结构信息,不包括表中的数据。如果你需要导出表的数据,你可以使用不同的工具或方法,如Oracle数据泵工具或SQL查询。
2.使用数据泵工具(expdp):
可以分开导出表结构和数据,而不是一次性导出两者。你可以使用Oracle Data Pump工具(`expdp`)来完成这个任务。
1. 导出表结构:
expdp username/password@db_name DIRECTORY=dpump_dir DUMPFILE=table_structure.dmp CONTENT=METADATA_ONLY TABLES=your_table
- `username` 和 `password` 是用于登录到数据库的用户名和密码。
- `db_name` 是数据库的连接名。
- `DIRECTORY` 指定了数据泵导出文件存储的目录。
- `DUMPFILE` 是导出文件的名称。
- `CONTENT` 设置为 `METADATA_ONLY`,以指定只导出表的元数据(结构)。
- `TABLES` 参数后跟要导出的表的名称。
2. 导出表数据:
expdp username/password@db_name DIRECTORY=dpump_dir DUMPFILE=table_data.dmp CONTENT=DATA_ONLY TABLES=your_table
- 与上述命令类似,不同之处在于 `CONTENT` 设置为 `DATA_ONLY`,以指定只导出表的数据。
这将分别导出表结构和表数据到两个不同的文件中。你可以根据需要执行这两个导出操作,并确保选择适当的数据泵导出文件以获取所需的内容。
通过这种方式,你可以更细粒度地控制导出操作,确保只导出你需要的数据或结构。
3.使用Oracle SQL Developer:
1. 打开 Oracle SQL Developer:打开你的 Oracle SQL Developer 工具,并连接到你的目标数据库。
2. 选择要导出的表:在左侧的 "Connections" 面板中,展开你的数据库连接,然后展开 "Tables" 节点。选择你要导出结构的表。
3. 生成DDL脚本:右键单击选择的表,然后选择 "SQL" > "DDL" > "Generate". 这将生成表的DDL脚本。
4. 导出DDL脚本:在 "SQL Worksheet" 中,你将看到生成的DDL脚本。你可以在这个工作表中编辑和查看DDL。如果你想将DDL保存到文件中,请执行以下步骤:
- 在 "SQL Worksheet" 工具栏中,单击 "File" > "Save"。
- 选择保存位置和文件名,确保文件扩展名为 `.sql`。
5. 保存DDL文件:保存DDL文件到你的计算机上,这个文件包含了选定表的结构信息。
这个脚本包含了表的结构信息。你可以在需要时使用这个DDL文件来重新创建表的结构或在其他数据库中部署它。
需要注意的是,这个DDL脚本只包含表的结构信息,不包括表中的数据。如果你需要导出数据,你可以使用其他方法,如使用数据泵工具或SQL查询。
以上就是小景为您带来的全部内容,希望可以实际解决您的问题。
小景的Dba之路--如何导出0记录表以及数据泵的使用的更多相关文章
- 实验:Oracle数据泵导出导入之序列问题
今天同事提出了一个问题: 使用数据泵expdp导出1个schema,有个表主键是触发器自增的id,导入测试库测试时,发现表里的数据比自增序列的值要大.导致插入数据报错. 最终结论是: 由于数据库先进行 ...
- oracle数据泵导出导入
先创建一个目录:比如 Create or Replace directory DATA_PUMP_DIR as 'D:\DataPipe'; 然后给导入导出的用户赋权限: Grant read ...
- 【EXPDP/IMPDP】ORACLE数据泵导入导出案例(expdp & impdp)
概要: 因项目需要,通常需要将生产库下的部分数据抽取并恢复到测试库上 本文主要介绍数据泵导入导出的几种情况以及错误处理 案例环境: rhel-server-6.5-x86_64 oracle 11.2 ...
- 【EXPDP】expdp/impdp数据泵远程导入导出
Oracle在10g的时候有一个很好用的导出工具expdp(数据泵) 但是这个工具好用的同时,有一个局限,就是必须用本地的用户才可以导出数据,也就是说数据泵只能导出本地数据库的数据 但是如果业务需求是 ...
- Hybrid小程序混合开发之路 - 数据交互
HTML+CSS是历史悠久.超高自由度.控制精准.表现能力极强.编码简单.学习门槛超低.真跨平台的一种UI界面开发方式. 本文介绍的是微信小程序和H5混合开发的一种数据交互方式. 很多应用在原生界面中 ...
- Oracle数据泵导出使用并行参数,单个表能否真正的并行?
对于Oracle 数据泵expdp,impdp是一种逻辑导出导入迁移数据的一个工具,是服务端的工具,常见于DBA人员使用,用于数据迁移.从A库迁移至B库,或者从A用户迁移至B用户等. 那么有个疑问? ...
- Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(上)
<Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(上)> <Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(下)> 目的:指导项 ...
- oracle表分区、表分析及oracle数据泵文件导入导出开心版
1.先说oracle表分区是什么吧,这样吧我们来举个桃子,栗子太小,我们就不举了,我们来举个桃子. 你有500万份文件,你要把他存在磁盘上,好嘛,我们就一个文件夹,500万分文件在那儿杵着,我们想找到 ...
- [terry笔记]Oracle数据泵-schema导入导出
数据泵是10g推出的功能,个人倒数据比较喜欢用数据泵. 其导入的时候利用remap参数很方便转换表空间以及schema,并且可以忽略服务端与客户端字符集问题(exp/imp需要排查字符集). 数据泵也 ...
- Oracle基础 数据泵导出/导入Expdp/impdp(转)
一.EXPDP和IMPDP使用说明 Oracle Database 10g引入了最新的数据泵(Data Dump)技术,数据泵导出导入(EXPDP和IMPDP)的作用 1)实现逻辑备份和逻辑恢复. 2 ...
随机推荐
- SQL SERVER 错误捕捉与事务
在SQL server (MSSQL)写代码中,不管是一段SQL代码,还是存储过程等,有的时候总会遇见程序报错,导致系统崩溃, 与C#同理,SQL SERVER 也提供了回滚与错误捕捉,事务比较复杂, ...
- unity前后端通信
1. 配置请求体中的Json字符串 1 request_data = new RequestBodyClass(); 2 request_data.a = "Json第一个字段"; ...
- 使用C#编写.NET分析器(三)
译者注 这是在Datadog公司任职的Kevin Gosse大佬使用C#编写.NET分析器的系列文章之一,在国内只有很少很少的人了解和研究.NET分析器,它常被用于APM(应用性能诊断).IDE.诊断 ...
- ZEGO自研RTC+直播系统架构,如何支撑一场高质量直播
近年来得益于网络基础设施的进步,实时音视频(Real-Time Communication,以下简称 RTC)和直播(采用 CDN 进行内容分发)在各行业迅速落地,在疫情的催化下更是推动传统的教育.会 ...
- 使用mybatis-generator 能生成 但是实际使用时抛出异常Invalid bound statement (not found)
好多好多好多红 但是重点是一句org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): {}.d ...
- Dubbo的高级特性:服务管控篇
王有志,一个分享硬核Java技术的互金摸鱼侠 加入Java人的提桶跑路群:共同富裕的Java人 上一篇,我们已经介绍了 DUbbo 在服务治理方面提供的特性,今天我们一起来看看 Dubbo 在其它方面 ...
- msvc C++编译链接
C++编译链接 C++编译链接 静态库编译 C RunTimeLibrary 链接过程 动态库编译 场景问题加深理解 总结 静态库编译 C RunTimeLibrary C++是C的超集,C RunT ...
- DataGridView 控件分页
在使用Winform开发桌面应用时,工具箱预先提供了丰富的基础控件,利用这些基础控件可以开展各类项目的开发.但是或多或少都会出现既有控件无法满足功能需求的情况,或者在开发类似项目时,我们希望将具有相同 ...
- pandas 某列不为空的行
df = df[df['my_col'].notnull()]
- The language server needs at least PHP 7.1 installed. Version found: 7.0.10
解决方案: 打开VS Code 文件 -> 首选项 -> 设置 -> 在 settings.json 中编辑 在 settings.json 中,加入: "php.exec ...