参考http://www.itpub.net/showthread.php?s=&threadid=111356

解决方案 »

  1.   

    dmp文件的第2、3字节为 03 52  (ZHS16CGB231280)
    可是我在注册表里修改了,cmd----set了一下还是有错误:
    IMP-00003: 遇到ORACLE 错误922
      

  2.   

    用支持这个dmp的oracle客户端,做个网络映射到你的oracle服务端,远程导,我碰到这个问题就是这样解决的
      

  3.   

    在不同字符集的数据库之间导入数据的方法:
    以US7ASCII的库中导出的数据导入到字符集为ZHS16GBK的库为例子:
    假设US7ASCII的库是A机,字符集为ZHS16GBK的库为B机
    1。确定你A机上的oracle用户的.profile文件中的NLS_LANG是US7ASCII,正常的导出所有数据。
    2。然后传到B机上,bin模式,然后在B机上设定好oracle用户的设定环境变量NLS_LANG=AMERICAN_AMERICA.US7ASCII
    以sys用户执行update props$ set values$='US7ASCII'
    where name='NLS_CHARACSET';
    3。正常的导入数据至ZHS16GBK的数据库中去,重新启动数据库,此时查看原来导入的数据应该已经中文了。
    4。把环境变量改回来,NLS_LANG=AMERCIAN_AMERICA.ZHS16GBK
    以sys用户登陆ZHS16GBK的数据库然后执行一下语句:
    update props$ set values$='ZHS16GBK'
    where name='NLS_CHARACSET';
    重新启动数据库让其修改生效即可。
    8。如果不放心,可以把当前ZHS16GBK数据库中的数据正常exp出来,然后重新建库后正常导入。