impdp报错: ORA-39064: 无法写入日志文件 ORA-29285: 文件写入错误
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