代码改变世界

impdp报错: ORA-39064: 无法写入日志文件 ORA-29285: 文件写入错误

  abce  阅读(9201)  评论(0编辑  收藏  举报

windows平台下,oracle 11.2.0.1在使用impdp向测试环境导入数据的时候,报出如下错误:

 

 

错误原因:

数据泵在写日志文件的时候,使用的是数据库字符集。如果客户端的环境变量NLS_LANG得值和数据库字符集不一致的话,日志中显示的表名称可能和终端屏幕输出的不一致。
数据泵内部使用的是包UTL_FILE,在和NLS转换的时候可能不能输出字符。

1
2
3
4
5
6
7
8
#查看测试库
SQL> select userenv('language') from dual;
 
USERENV('LANGUAGE')
--------------------------------------------------------------------------------
SIMPLIFIED CHINESE_CHINA.AL32UTF8
 
SQL>

 

查看操作系统的NLS_LANG设置:

1
2
3
4
5
运行 --> regedit -->查找 键值 NLS_LANG 将字符集
 
注册表路径:HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\KEY_OraDb11g_home1\NLS_LANG
 
SIMPLIFIED CHINESE_CHINA.ZHS16GBK

  

解决方案:

将客户端NLS_LANG的值设置和数据库字符集一致

SIMPLIFIED CHINESE_CHINA.ZHS16GBK

修改为:

SIMPLIFIED CHINESE_CHINA.AL32UTF8

  

 

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2015-07-27 Private strand flush not complete
2015-07-27 log file switch (checkpoint incomplete)
点击右上角即可分享
微信分享提示