zoukankan      html  css  js  c++  java
  • oracle 如何查询/修改dmp文件的字符集

    1、如何查询dmp文件的字符集

      用oracle的exp工具导出的dmp文件也包含了字符集信息,dmp文件的第2和第3个字节记录了dmp文件的字符集。如果dmp文件不大,比如只有几M或几十M,可以用UltraEdit打开(16进制方式),看第2第3个字节的内容,如0354,然后用以下SQL查出它对应的字符集:

      SQL> select nls_charset_name(to_number('0354','xxxx')) from dual;

      ZHS16GBK

      如果dmp文件很大,比如有2G以上(这也是最常见的情况),用文本编辑器打开很慢或者完全打不开,可以用以下命令(在unix主机上):

      cat exp.dmp |od -x|head -1|awk '{print $2 $3}'|cut -c 3-6

      然后用上述SQL也可以得到它对应的字符集。

    2、修改dmp文件字符集

      上文说过,dmp文件的第2第3字节记录了字符集信息,因此直接修改dmp文件的第2第3字节的内容就可以‘骗’过oracle的检查。这样做理论上也仅是从子集到超集可以修改,但很多情况下在没有子集和超集关系的情况下也可以修改,我们常用的一些字符集,如 US7ASCII,WE8ISO8859P1,ZHS16CGB231280,ZHS16GBK基本都可以改。

    因为改的只是dmp文件,所以影响不大。

      具体的修改方法比较多,最简单的就是直接用UltraEdit修改dmp文件的第2和第3个字节。比如想将dmp文件的字符集改为 ZHS16GBK,可以用以下SQL查出该种字符集对应的16进制代码:

      SQL> select to_char(nls_charset_id('ZHS16GBK'), 'xxxx') from dual;

      0354

      然后将dmp文件的2、3字节修改为0354即可。

      如果dmp文件很大,用ue无法打开,就需要用程序的方法了。网上有人用java存储过程写了转换的程序(用java存储过程的好处是通用性教好,缺点是比较麻烦)。我在windows下测试通过。但要求oracle数据库一定要安装JVM选项。有兴趣的朋友可以研究一下程序代码。

  • 相关阅读:
    使用部分函数时并未include其所在头文件,但是能编译成功且能运行,为什么?
    ubuntu开发机所需工具,做个记录,不断补充
    c cpp编程用到的系统边角与其拾遗
    几个递进的make file
    可以用命令行控制eclipse断点增加删除、远程调试创建与启动的插件
    Mac 从睡眠恢复后没有声音的问题
    [netty4][netty-handler]netty之idle handler处理
    《将博客搬至CSDN》
    python2与python3中__metacalss__的不同用法
    python3 type和object的关系
  • 原文地址:https://www.cnblogs.com/samwang88/p/7001765.html
Copyright © 2011-2022 走看看