导入数据库文件中断,提示ora-39064:无法写入日志文件;ora-29285:文件写入错误

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

错误原因:

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

解决方法:

1、查看数据库字符集

SQL> select userenv('language') from dual;

USERENV('LANGUAGE')
-------------------------------------------------
SIMPLIFIED CHINESE_CHINA.AL32UTF8

2、查看操作系统的NLS_LANG设置:

打开注册表(regedit),进入HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\KEY_OraDb11g_home1,查看NLS_LANG键值为SIMPLIFIED CHINESE_CHINA.ZHS16GBK;

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

SIMPLIFIED CHINESE_CHINA.ZHS16GBK

修改为:

SIMPLIFIED CHINESE_CHINA.AL32UTF8

如图所示:

posted @ 2020-10-25 12:23  gsy111bbb  阅读(210)  评论(0)    收藏  举报