小景的Dba之路--impdp导入数据问题报错排查总结
小景最近在工作中遇到了一个问题,用impdp做数据导入的时候,有以下报错,下面是问题排查过程:


首先看到了ORA-01950:no privileges on tablespace ‘PUBDATA’ 这个报错,小景想到了以下原因:
- 权限问题:ORA-01950错误表示用户没有在PUBDATA表空间上的特定对象的权限。这可能是由于数据库权限配置不当,导致导出进程无法访问相关的表空间和对象。解决方案是检查用户权限设置,确保用户拥有足够的权限来执行数据导出操作。
- 作业不存在:ORA-31626错误表示尝试操作的作业不存在。这可能是由于指定的作业名称不正确或者作业已经被删除或更改。需要检查作业名称的拼写和准确性,并确保作业存在且具有正确的配置。
- 无法创建主表:ORA-31633错误表示无法创建主表。这可能是由于表空间不足、磁盘空间不足或其他存储问题导致的。需要检查数据库的存储配置和可用空间,确保有足够的空间来创建所需的表结构。
- 内部错误:ORA-06512错误表示遇到了内部错误。这可能是由于Oracle数据库内部的问题或配置不当导致的。需要进一步检查Oracle数据库的状态和配置,以及版本兼容性问题。
然后我把关注点主要聚焦在ORA-01950权限问题和ORA-31633无法创建主表这两个报错上,针对ORA-01950权限问题,我这边直接用system用户来操作,然后查了下对应的用户下的表空间:
1 SELECT
2 u.username,
3 t.tablespace_name,
4 ROUND((t.total_mb - t.free_mb) / t.total_mb * 100, 2) AS used_percent
5 FROM
6 dba_users u
7 JOIN
8 (SELECT
9 user#,
10 SUM(bytes) / 1024 / 1024 AS total_mb,
11 SUM(bytes) / 1024 / 1024 - SUM(NVL(free_bytes, 0)) / 1024 / 1024 AS free_mb
12 FROM
13 dba_data_files
14 WHERE
15 owner = 'SYSTEM'
16 GROUP BY user#) t
17 ON
18 u.user# = t.user#;
这个查询将返回SYSTEM用户所拥有的每个表空间的名称、使用率和总大小。通过这个查询,小景发现system和sysaux用户下的表空间使用率都达到了99%,那么下面就是要进行表空间的拓展:
1. 登录到数据库
使用SQL*Plus或其他数据库客户端工具,通过具有足够权限的用户(如SYSDBA)连接到目标数据库。
2. 检查表空间状态
在执行任何操作之前,了解表空间的使用情况是非常重要的。你可以使用以下查询来获取更详细的表空间使用情况:
1 SELECT
2 tablespace_name,
3 SUM(bytes) / 1024 / 1024 AS total_mb,
4 SUM(used_bytes) / 1024 / 1024 AS used_mb,
5 SUM(free_bytes) / 1024 / 1024 AS free_mb,
6 ROUND((SUM(used_bytes) / SUM(bytes)) * 100, 2) AS used_percent
7 FROM
8 dba_data_files
9 GROUP BY tablespace_name;
这将显示每个表空间的名称、总大小、已用大小、可用大小以及使用百分比。
3. 添加数据文件到表空间
使用ALTER TABLESPACE语句添加新的数据文件。你需要指定数据文件的路径、文件名以及大小。例如:
这将向名为your_tablespace_name的表空间添加一个大小为500MB的数据文件。确保替换/path_to_datafile/datafile_name.dbf为实际的文件路径和名称。
4. 调整现有数据文件的大小
如果需要调整现有数据文件的大小,可以使用以下语句:
这将调整名为/path_to_datafile/datafile_name.dbf的数据文件的大小为1024MB。确保替换为实际的文件路径和名称。
5. 重新构建索引(可选)
在某些情况下,添加或调整数据文件后,可能需要重新构建表空间的索引以优化性能。你可以使用以下命令来重新构建索引:
1 ALTER INDEX your_tablespace_name REBUILD;
这将重新构建存储在名为your_tablespace_name的表空间中的所有索引。确保替换为实际的表空间名称。
6. 验证扩展操作(可选)
执行适当的查询和检查,以确保表空间已成功扩展并且应用程序能够正常使用。你可以再次运行步骤2中的查询来验证扩展是否成功。确保检查数据库的性能和响应时间,以确保一切正常。
7. 定期监控和维护(可选)
为了保持表空间的健康和性能,建议定期监控表空间的使用情况,并执行常规的维护任务,如重新组织表和索引。确保在需要时根据业务需求调整表空间大小。可以使用Oracle提供的工具和监视工具来监控表空间的使用情况。
至此,问题完美解决,下面是一些总结延申及拓展:
1. 检查该用户是否具有表空间中特定对象的访问权限:
- 特定对象的访问权限:用户需要具有对PUBDATA表空间中特定对象的访问权限。您可以查询数据库中的权限表,例如USER_TAB_PRIVS,以检查用户是否具有对目标对象的访问权限。
- 1 sql`SELECT * FROM USER_TAB_PRIVS WHERE TABLE_NAME = 'YOUR_TABLE';`
- 表空间的存储权限:用户还需要具有在PUBDATA表空间中创建、修改和删除对象的存储权限。您可以查询数据库中的权限表,例如USER_TS_QUOTAS,以检查用户在表空间上的配额和限制。
- 1 sql`SELECT * FROM USER_TS_QUOTAS WHERE TABLESPACE_NAME = 'PUBDATA';`
- 特定对象的访问权限:用户需要具有对PUBDATA表空间中特定对象的访问权限。您可以查询数据库中的权限表,例如USER_TAB_PRIVS,以检查用户是否具有对目标对象的访问权限。
2. impdp中的重定向:
1 impdp system/123456@orcl directory=kdbak schemas=K3CLOUDDCUSERORACLE dumpfile=K3Cloud20200717000101.dmp table_exists_action=replace exclude=statistics transform=OID:N Remap_schema=hr:hr2
其中要指定一下schema,schema就是导入的目标用户,需要重定向就用remap即可,例如:你的表都在hr这个用户下,还导入到hr下,就指定schema=hr,如果要导入到hr2用户下,就用remap重定向。
最后,希望小景的这篇文章可以帮助您解决实际工作中的问题,有什么问题可以评论区或者关注我的微信公众号来交流。
小景的Dba之路--impdp导入数据问题报错排查总结的更多相关文章
- windows环境下使用MySQL导入数据乱码报错的解决办法
Linux及Mac系统下使用source xxx.sql 可直接导入测试数据(注意必须先切换到当前xxx.sql的目录下), 但在Windows环境下导入会出现乱码报错的情况, 主要是因为编码的问题, ...
- mysql 导入数据是报错:2006 - MySQL server has gone away
导SQL数据库结构+数据时,如果数据是批量插入的话会报错:2006 - MySQL server has gone away. 解决办法:找到你的mysql目录下的my.ini配置文件,加入以下代码 ...
- Oracle impdp导入数据临时表空间与undo表空间爆满解决实例
Oracle impdp导入数据临时表空间与undo表空间爆满解决实例 [日期:2018-01-24] 来源:Linux社区 作者:rangle [字体:大 中 小] 针对Oracle数据迁移, ...
- 【MySQL篇】Navicat导入SQL文件报错终极解决方案
面对大数据库文件(一般50M以上),使用Navicat导入的时候容易出现[ERR]2006等报错问题,此文提供了几种办法,包括修改MySQL的配置参数在网上也有很多详细教程介绍过,但此文精彩处在于前面 ...
- 往sde中导入要素类报错000732
sde可以成功连接,可以在Server中注册. 但是向sde中导入要素类报错000732,如图所示. 点击红色圆圈提示 ERROR 000732. 将路径修改为绝对路径即可,如下图所示.
- Android导入依赖appcompat-v7报错
Android导入依赖appcompat-v7报错 导入appcompat-v7时报错了 导入的是implementation 'com.android.support:appcompat-v7: ...
- PyCharm导入tensorflow包报错的问题
[注]PyCharm导入tensorflow包报错的问题 若是你也遇到这个问题,说明你也没有理解tensorflow到底在哪里. 当安装了anaconda3.6后,在PyCharm中设置interpr ...
- 导入json文件报错,TypeError expected string or buffer
导入json文件报错,TypeError expected string or buffer 原因:用字符串赋值后,python会把双引号转换为单引号 import json data = [{&qu ...
- 【SQLServer2008】之如何导入mdf,ldf文件、导入.mdf文件报错解决问题以及如何获得Authenticated Users 权限
一.如何导入mdf,ldf文件: 链接:http://jingyan.baidu.com/article/09ea3ede21258cc0afde3943.html 二.导入.mdf文件报错解决问题 ...
- Sqoop- sqoop将mysql数据表导入到hive报错
sqoop将mysql数据表导入到hive报错 [root@ip---- lib]# sqoop import --connect jdbc:mysql://54.223.175.12:3308/gx ...
随机推荐
- docker的基本命令使用
docker image/images docker image与images 的区别在于docker images可以直接使用,docker image不可以直接使用,看例子 [root@docke ...
- DNS解析中CNAME和MX记录冲突
转载:DNS中CNAME和MX记录的冲突 在DNS解析中,CNAME记录与其他记录往往是互斥的.最常见的是CNAME记录和MX记录的互斥.例如我们在http://example.com部署官网,通过C ...
- MySQL 基础(四)锁
解决并发事务带来的问题 写-写情况 任意一种事务隔离级别都不允许 "脏写" 的发生,因为这样会使得数据混乱.所以,当多个未提交的事务相继对一条记录进行改动时,就需要使得这些事务串行 ...
- CUDA个人入坟笔记
CUDA是建立在NVIDIA的GPUs上的一个通用并行计算平台和编程模型,基于CUDA编程可以利用GPUs的并行计算引擎来更加高效地解决比较复杂的计算难题.近年来,GPU最成功的一个应用就是深度学习领 ...
- gitlab jenkins 安装笔记
gitlab gitlab ce是社区版本,ee是企业版本,称为gitee. https://packages.gitlab.com/gitlab/gitlab-ce/install 通过运行curl ...
- Xshell与Xftp安装与使用
Xshell与Xftp安装 软件安装:官网或者应用商店 安装结束 nslicense.dll替换 下载文件 使用 登录 双击刚刚建立的连接 表示建立成功 点击文件传输 右边就是服务器的文件,左边就是本 ...
- Java 编辑、删除Excel中的超链接
本文介绍如何编辑Excel文档中的超链接,包括编辑超链接显示文本.链接地址及删除指定超链接.使用免费版Excel类库工具,Free Spire.XLS for Java.Jar包获取可在官方网站下载, ...
- 云图说丨云数据库GaussDB(for MySQL)事务拆分大揭秘
摘要:数据库代理提供事务拆分的功能,能够将事务内写操作之前的读请求转发到只读节点,降低主节点负载. 本文分享自华为云社区<[云图说]第270期 云数据库GaussDB(for MySQL)事务拆 ...
- 统一元数据,数据湖Catalog让大数据存算分离不再是问题
摘要:为了解决现阶段大数据存算分离痛点问题,华为云大数据推出重量级数据湖Catalog服务. 1 背景 随着5G.IoT等技术的发展,企业积累了越来越多的数据,需要激发更多的数据价值变现.传统大数据平 ...
- JS引擎(1):JS引擎擂台赛,JavaScript引擎的特征比较及术语科普
上篇介绍过JavaScript引擎的历史,<JS引擎(0):起底各种JavaScript引擎群雄争霸之路> 一些流行的 JavaScript 引擎 SpiderMonkey ,Brenda ...