小景的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 ...
随机推荐
- elementui中deep的用法/deep/
在做第一个vue项目时遇到了一个问题,在使用elementui中的Drawer(抽屉组件时),想要修改Drawer的标题,尝试着修改title的样式,但没有效果,尝试了很多方法,最后用/deep/解决 ...
- 分别在Windows系统和Linux系统环境安装anaconda3和tensorflow
Windows系统环境 一.安装anaconda 这里安装的是Anaconda3-2019.03-Windows-x86_64.exe(python3.7版本) 二.检查安装环境 1.若anacond ...
- CocosCreator基础
跳转到底部 目录 CocosCreator项目结构: 资源文件夹(assets) 资源库(library) 本地设置(local) 项目设置(settings) project.json 构建目标(b ...
- C语言循环坑 -- continue的坑
文章目录 前言 一.continue语法 1.continue的作用 2.语法 二.大坑项目 题目 分析 正确写法 三.进坑调试 第一种 第二种 总结 前言 在使用continue和break时,会出 ...
- 这可能是前端处理excel最好的工具了
大家好,我是程序视点的小二哥! 今天小二哥要分享的是一个纯前端实现读取和导出excel文件的工具库:ExcelJS ExcelJs 简介 功能十分简单: 读取,操作并写入电子表格数据和样式到 XLSX ...
- 并发编程-CompletableFuture解析
1.CompletableFuture介绍 CompletableFuture对象是JDK1.8版本新引入的类,这个类实现了两个接口,一个是Future接口,一个是CompletionStage接口. ...
- Avalonia 列表拖拽替换
实现目标,在一个ListBox中选择一个子项进行拖拽到另一个ListBox中,拖拽到某一子项区域进行替换 下面是axaml代码 1 <ListBox 2 Name="consumabl ...
- K8S | Config应用配置
绕不开的Config配置: 一.背景 在自动化流程中,对于一个应用来说,从开发阶段的配置管理,到制作容器镜像,再到最后通过K8S集群发布为服务,整个过程涉及到的配置非常多: 应用环境:通常是指代码层面 ...
- 【动画进阶】神奇的 3D 磨砂玻璃透视效果
最近,群友分享了一个很有意思的效果: 原效果的网址:frosted-glass.该效果的几个核心点: 毛玻璃磨砂效果 卡片的 3D 旋转跟随效果 整体透明度和磨砂感.以及卡片的 3D 形态会随着用户移 ...
- CSS基础(4)
目录 1 定位 1.1 为什么需要定位 1.2 定位组成 1.2.1 边偏移(方位名词) 1.2.2 定位模式 (position) 1.3 定位模式介绍 1.3.1 静态定位(static) - 了 ...