精华内容
下载资源
问答
  • IMP数据入库时报imp-00098错误,查了一下发现导入客户端字符集同服务器字符集不一致,修改客户端环境变量同服务器一致 export NLS_LANG= AMERICAN_AMERICA.ZHS16GBK(unix系统) ...

    IMP数据入库时报imp-00098错误,查了一下发现导入客户端字符集同服务器字符集不一致,修改客户端环境变量同服务器一致

    export NLS_LANG= AMERICAN_AMERICA.ZHS16GBK(unix系统)

    set nls_lang=AMERICAN_AMERICA.ZHS16GBK(WINDOWS)

    重新导入,错误解决

    来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/79497/viewspace-697866/,如需转载,请注明出处,否则将追究法律责任。

    转载于:http://blog.itpub.net/79497/viewspace-697866/

    展开全文
  • 生产环境中经常使用到Oracle的IMP导入和EXP导出来功能来达到数据迁移的目的,通常在源数据库和目标数据库中查询字符集是否致, 测试环境中导入IMP导入报错信息如下: 导入命令如下: [oracle@localhost.localdomain:/...

    生产环境中经常使用到Oracle的IMP导入和EXP导出来功能来达到数据迁移的目的,通常在源数据库和目标数据库中查询字符集是否致,

    测试环境中导入IMP导入报错信息如下:

    导入命令如下:

    [oracle@localhost.localdomain:/soft]$imp scott/scott file=/soft/scott_v1.dmp log=/soft/scott_v1.log ignore=y full=y

    Import: Release 11.2.0.4.0 - Production on Sun Oct 22 16:26:27 2017

    Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.


    Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
    With the Partitioning, OLAP, Data Mining and Real Application Testing options

    Export file created by EXPORT:V11.02.00 via conventional path
    import done in ZHS16GBK character set and AL16UTF16 NCHAR character set --提示字符集不一致
    . importing SCOTT's objects into SCOTT
    . . importing table                        "BONUS"          0 rows imported
    . . importing table                         "DEPT"
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_DEPT) violated--提示各种乱码问题
    Column 1 10
    Column 2 ǎ
    Column 3 
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_DEPT) violated
    Column 1 20
    Column 2 в
    Column 3 ±±
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_DEPT) violated
    Column 1 30
    Column 2 к
    Column 3 
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_DEPT) violated
    Column 1 40
    Column 2 
    Column 3           0 rows imported
    . . importing table                          "EMP"
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7369
    Column 2 itpux01
    Column 3 τ
    Column 4 7902
    Column 5 17-DEC-1980:00:00:00
    Column 6 800
    Column 7 
    Column 8 20
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7499
    Column 2 itpux02
    Column 3 к
    Column 4 7698
    Column 5 20-FEB-1981:00:00:00
    Column 6 1600
    Column 7 300
    Column 8 30
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7521
    Column 2 itpux03
    Column 3 к
    Column 4 7698
    Column 5 22-FEB-1981:00:00:00
    Column 6 1250
    Column 7 500
    Column 8 30
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7566
    Column 2 itpux04
    Column 3 
    Column 4 7839
    Column 5 02-APR-1981:00:00:00
    Column 6 2975
    Column 7 
    Column 8 20
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7654
    Column 2 itpux05
    Column 3 к
    Column 4 7698
    Column 5 28-SEP-1981:00:00:00
    Column 6 1250
    Column 7 1400
    Column 8 30
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7698
    Column 2 itpux06
    Column 3 
    Column 4 7839
    Column 5 01-MAY-1981:00:00:00
    Column 6 2850
    Column 7 
    Column 8 30
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7782
    Column 2 itpux07
    Column 3 
    Column 4 7839
    Column 5 09-JUN-1981:00:00:00
    Column 6 2450
    Column 7 
    Column 8 10
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7788
    Column 2 itpux08
    Column 3 ·
    Column 4 7566
    Column 5 19-APR-1987:00:00:00
    Column 6 3000
    Column 7 
    Column 8 20
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7839
    Column 2 itpux09
    Column 3 
    Column 4 
    Column 5 17-NOV-1981:00:00:00
    Column 6 5000
    Column 7 
    Column 8 10
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7844
    Column 2 itpux10
    Column 3 к
    Column 4 7698
    Column 5 08-SEP-1981:00:00:00
    Column 6 1500
    Column 7 0
    Column 8 30
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7876
    Column 2 itpux11
    Column 3 τ
    Column 4 7788
    Column 5 23-MAY-1987:00:00:00
    Column 6 1100
    Column 7 
    Column 8 20
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7900
    Column 2 itpux12
    Column 3 τ
    Column 4 7698
    Column 5 03-DEC-1981:00:00:00
    Column 6 950
    Column 7 
    Column 8 30
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7902
    Column 2 itpux13
    Column 3 ·
    Column 4 7566
    Column 5 03-DEC-1981:00:00:00
    Column 6 3000
    Column 7 
    Column 8 20
    IMP-00019: row rejected due to ORACLE error 1
    IMP-00003: ORACLE error 1 encountered
    ORA-00001: unique constraint (SCOTT.PK_EMP) violated
    Column 1 7934
    Column 2 itpux14
    Column 3 τ
    Column 4 7782
    Column 5 23-JAN-1982:00:00:00
    Column 6 1300
    Column 7 
    Column 8 10          0 rows imported
    . . importing table                     "SALGRADE"          5 rows imported
    About to enable constraints...
    Import terminated successfully with warnings.




    如何查询字符集

    方法1:查询表(在知道源数据库和目标数据库):

    select * from nls_database_parameters;


    1    NLS_LANGUAGE           AMERICAN
    2    NLS_TERRITORY           AMERICA
    3    NLS_CURRENCY           $
    4    NLS_ISO_CURRENCY    AMERICA
    5    NLS_NUMERIC_CHARACTERS    .,
    6    NLS_CHARACTERSET    ZHS16GBK --此处是显示字符集
    7    NLS_CALENDAR    GREGORIAN
    8    NLS_DATE_FORMAT    DD-MON-RR
    9    NLS_DATE_LANGUAGE    AMERICAN
    10    NLS_SORT    BINARY
    11    NLS_TIME_FORMAT    HH.MI.SSXFF AM
    12    NLS_TIMESTAMP_FORMAT    DD-MON-RR HH.MI.SSXFF AM
    13    NLS_TIME_TZ_FORMAT    HH.MI.SSXFF AM TZR
    14    NLS_TIMESTAMP_TZ_FORMAT    DD-MON-RR HH.MI.SSXFF AM TZR
    15    NLS_DUAL_CURRENCY    $
    16    NLS_COMP    BINARY
    17    NLS_LENGTH_SEMANTICS    BYTE
    18    NLS_NCHAR_CONV_EXCP    FALSE
    19    NLS_NCHAR_CHARACTERSET    AL16UTF16
    20    NLS_RDBMS_VERSION    11.2.0.4.0

    方法2:在不知道dmp中字符集是什么,如何查看

    1  查看dmp文件的中字符集

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

    结果为:0345

    2  然后用以下SQL查出它对应的字符集:

    SQL> select nls_charset_name(to_number('0354','xxxx')) from dual;
    NLS_CHARSET_NAME(TO_NUMBER('0354','XXXX'
    ----------------------------------------
    ZHS16GBK


    如何修改字符集

    修改字符集有几种方法

    方法1、修改服务器端中的环境变量中的字符集设置(服务器端导入只要配置服务器端,客户端导入的话还要设置客户端字符集),注:此方法在服务器修改后再及时修改回去

    方法2、修改数据库中字符集

    方法3、修改dmp文件中字符集


    本环境是在服务器端导入的,所以采用方法1

    1、查询当前环境变量

    [oracle@localhost.localdomain:/soft]$cat ~/.bash_profile 
    # .bash_profile

    # Get the aliases and functions
    if [ -f ~/.bashrc ]; then
        . ~/.bashrc
    fi

    # User specific environment and startup programs

    PATH=$PATH:$HOME/bin

    export PATH

    # Oracle Settings oracle
    TMP=/tmp; export TMP
    TMPDIR=$TMP; export TMPDIR
    PS1="[`whoami`@`hostname`:"'$PWD]$'
    alias sqlplus="rlwrap sqlplus"
    alias rman="rlwrap rman"
    alias alert="cd /oracle/app/oracle/diag/rdbms/db01/db01/trace"
    alias lsnrctl="rlwrap lsnrctl"
    alias adrci="rlwrap adrci"
    export LANG=en_US
    ORACLE_BASE=/oracle/app/oracle; export ORACLE_BASE
    ORACLE_HOME=$ORACLE_BASE/product/11.2.0; export ORACLE_HOME
    ORACLE_SID=db01; export ORACLE_SID
    ORACLE_TERM=xterm; export ORACLE_TERM

    PATH=/usr/sbin:$PATH; export PATH
    PATH=$ORACLE_HOME/bin:$PATH; export PATH

    LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib; export LD_LIBRARY_PATH
    CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib; export CLASSPATH
    NLS_DATE_FORMAT="yyyy-mm-dd HH24:MI:SS"; export NLS_DATE_FORMAT
    NLS_LANG=AMERICAN_AMERICA.ZHS16GBK;export NLS_LANG

    if [ $USER = "oracle" ] || [ $USER = "grid" ]; then
            if [ $SHELL = "/bin/ksh" ]; then
             ulimit -p 16384
                  ulimit -n 65536
            else
                  ulimit -u 16384 -n 65536
            fi
            umask 022
    fi


    2、配置环境变量
    [oracle@localhost.localdomain:/soft]$vi ~/.bash_profile 

    3、查询配置后信息

    [oracle@localhost.localdomain:/soft]$cat ~/.bash_profile 
    # .bash_profile

    # Get the aliases and functions
    if [ -f ~/.bashrc ]; then
        . ~/.bashrc
    fi

    # User specific environment and startup programs

    PATH=$PATH:$HOME/bin

    export PATH

    # Oracle Settings oracle
    TMP=/tmp; export TMP
    TMPDIR=$TMP; export TMPDIR
    PS1="[`whoami`@`hostname`:"'$PWD]$'
    alias sqlplus="rlwrap sqlplus"
    alias rman="rlwrap rman"
    alias alert="cd /oracle/app/oracle/diag/rdbms/db01/db01/trace"
    alias lsnrctl="rlwrap lsnrctl"
    alias adrci="rlwrap adrci"
    export LANG=en_US
    ORACLE_BASE=/oracle/app/oracle; export ORACLE_BASE
    ORACLE_HOME=$ORACLE_BASE/product/11.2.0; export ORACLE_HOME
    ORACLE_SID=db01; export ORACLE_SID
    ORACLE_TERM=xterm; export ORACLE_TERM

    PATH=/usr/sbin:$PATH; export PATH
    PATH=$ORACLE_HOME/bin:$PATH; export PATH

    LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib; export LD_LIBRARY_PATH
    CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib; export CLASSPATH
    NLS_DATE_FORMAT="yyyy-mm-dd HH24:MI:SS"; export NLS_DATE_FORMAT
    #NLS_LANG=AMERICAN_AMERICA.ZHS16GBK;export NLS_LANG
    NLS_LANG=AMERICAN_AMERICA.AL16UTF16;export NLS_LANG

    if [ $USER = "oracle" ] || [ $USER = "grid" ]; then
            if [ $SHELL = "/bin/ksh" ]; then
             ulimit -p 16384
                  ulimit -n 65536
            else
                  ulimit -u 16384 -n 65536
            fi
            umask 022
    fi

    4、配置后可以通过SQL查询修改后字符集是否变更

    select * from nls_database_parameters;

    5、再次重启导入数据

    [oracle@localhost.localdomain:/soft]$imp scott/scott file=/soft/scott_v1.dmp log=/soft/scott_v1.log1 ignore=y full=y

    Import: Release 11.2.0.4.0 - Production on Sun Oct 22 16:46:17 2017

    Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.


    Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
    With the Partitioning, OLAP, Data Mining and Real Application Testing options

    Export file created by EXPORT:V11.02.00 via conventional path
    import done in ZHS16GBK character set and AL16UTF16 NCHAR character set
    . importing SCOTT's objects into SCOTT
    . . importing table                        "BONUS"          0 rows imported
    . . importing table                         "DEPT"          4 rows imported
    . . importing table                          "EMP"         14 rows imported
    . . importing table                     "SALGRADE"          5 rows imported
    About to enable constraints...
    Import terminated successfully without warnings.--此时导入比较成功,没有报错了


    知识延伸阅读


    测试的时候,本机oracle安装采用了utf8字符集,而项目的要求是gbk字符集,为了防止以后有不同字符集数据信息导入导出的问题,整理以下文档。
    修改oracle字符集新装了oracle,装为AL32UTF8格式,无奈一个工程导出包是ZHS16GBK格式,想了想办法转换,以下是学习 
    一、什么是oracle字符集
    Oracle字符集是一个字节数据的解释的符号集合,有大小之分,有相互的包容关系。ORACLE 支持国家语言的体系结构允许你使用本地化语言来存储,处理,检索数据。它使数据库工具,错误消息,排序次序,日期,时间,货币,数字,和日历自动适应本地化语言和平台。

    影响oracle数据库字符集最重要的参数是NLS_LANG参数。它的格式如下:

    NLS_LANG = language_territory.charset

    它有三个组成部分(语言、地域和字符集),每个成分控制了NLS子集的特性。其中:

    Language 指定服务器消息的语言,territory 指定服务器的日期和数字格式,charset 指定字符集。如:AMERICAN _ AMERICA. ZHS16GBK

    从NLS_LANG的组成我们可以看出,真正影响数据库字符集的其实是第三部分。所以两个数据库之间的字符集只要第三部分一样就可以相互导入导出数据,前面影响的只是提示信息是中文还是英文。

    二、如何查询Oracle的字符集

    很多人都碰到过因为字符集不同而使数据导入失败的情况。这涉及三方面的字符集,一是oracel server端的字符集,二是oracle client端的字符集;三是dmp文件的字符集。在做数据导入的时候,需要这三个字符集都一致才能正确导入。开始—运行—sqlplus,用户名输入:system as sysdba 
    密码:XXXX

    1、查询oracle server端的字符集

    有很多种方法可以查出oracle server端的字符集,比较直观的查询方法是以下这种:SQL>select userenv(‘language’) from dual;

    结果类似如下:AMERICAN _ AMERICA. ZHS16GBK (本机结果SIMPLIFIED CHINESE_CHINA.AL32UTF8)

    2、如何查询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也可以得到它对应的字符集。

    3、查询oracle client端的字符集

    这个比较简单。在windows平台下,就是注册表里面HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0\NLS_LANG 。还可以在dos窗口里面自己设置,比如:

    set nls_lang=AMERICAN_AMERICA.ZHS16GBK

    这样就只影响这个窗口里面的环境变量。

    在unix平台下,就是环境变量NLS_LANG。

    $echo $NLS_LANG

    AMERICAN_AMERICA.ZHS16GBK

    如果检查的结果发现server端与client端字符集不一致,请统一修改为同server端相同的字符集。

    三、修改oracle的字符集

    上文说过,oracle的字符集有互相的包容关系。如us7ascii就是zhs16gbk的子集,从us7ascii到zhs16gbk不会有数据解释上的问题,不会有数据丢失。在所有的字符集中utf8应该是最大,因为它基于unicode,双字节保存字符(也因此在存储空间上占用更多)。

    一旦数据库创建后,数据库的字符集理论上讲是不能改变的。因此,在设计和安装之初考虑使用哪一种字符集十分重要。根据Oracle的官方说明,字符集的转换是从子集到超集受支持,反之不行。如果两种字符集之间根本没有子集和超集的关系,那么字符集的转换是不受oracle支持的。对数据库server而言,错误的修改字符集将会导致很多不可测的后果,可能会严重影响数据库的正常运行,所以在修改之前一定要确认两种字符集是否存在子集和超集的关系。一般来说,除非万不得已,我们不建议修改oracle数据库server端的字符集。特别说明,我们最常用的两种字符集ZHS16GBK和ZHS16CGB231280之间不存在子集和超集关系,因此理论上讲这两种字符集之间的相互转换不受支持。

    1、修改server端字符集(不建议使用)

    在oracle 8之前,可以用直接修改数据字典表props$来改变数据库的字符集。但oracle8之后,至少有三张系统表记录了数据库字符集的信息,只改props$表并不完全,可能引起严重的后果。正确的修改方法如下:

    $sqlplus /nolog

    SQL>conn / as sysdba;

    以上方法测试不行,用scott/tiger登陆sqlplus然后connect sys/sys as sysdba,然后输入命令即可


    若此时数据库服务器已启动,则先执行SHUTDOWN IMMEDIATE命令关闭数据库服务器,然后执行以下命令:

    SQL>STARTUP MOUNT;

    SQL>ALTER SYSTEM ENABLE RESTRICTED SESSION;

    SQL>ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;

    SQL>ALTER SYSTEM SET AQ_TM_PROCESSES=0;

    SQL>ALTER DATABASE OPEN;

    SQL>ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK; //跳过超子集检测

    SQL>ALTER DATABASE national CHARACTER SET INTERNAL ZHS16GBK;

    这一行不起作用,执行后出错ORA-00933: SQL 命令未正确结束,不过执行上一行命令已经生效,其他文章里未提到本行。


    SQL>SHUTDOWN IMMEDIATE;

    SQL>STARTUP

    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选项。有兴趣的朋友可以研究一下程序代码

          在注册表中更改ORACLE的字符集编码方式的操作:regedit
          注册表路径:HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0
          把 NLS_LANG 的值从 SIMPLIFIED CHINESE_CHINA.ZHS16GBK
          改为 AMERICAN_AMERICA.US7ASCII   american_america.we8dec



    PS:
    Oracle UTF8 编码问题
    其实这是一个老问题,处理过多次了,每次都没有记住,这次决定写下来了。 其实很简单, 
    1)Oracle其实非常好,它会自动处理编码的转换。
    2)客户端(输入数据的机器)保证自结数据不出错就好了。
    在这个基础上,要用Oracle,并且用UTF8(多数情况下是为了应付多语言)存储数据,只需要做两件事情:
    a)Oracle数据库的实例的编码设置为UTF8;(NLS_LANG=AMERICAN _ AMERICA.UTF8)
    b)数据文件是什么编码,就将客户端设置为什么编码(例如NLS_LANG=AMERICAN _ AMERICA.ZHS16GBK  在注册表中修改),然后用工具导入数据。
    就可以了--在Java程序中可以尽情使用UTF8来显示中日韩等多国语言了'
















    本文转自xiaocao1314051CTO博客,原文链接:http://blog.51cto.com/xiaocao13140/1975064 ,如需转载请自行联系原作者


    展开全文
  • 使用exp/imp 导入导出时,需要设定NLS_LANG= ...生成的dmp文件根据客户端的字符集来定(如果你没有设置的话),这样如果导出源客户端和目标端数据库字符集不一致imp导入就会出现乱码;而expdp/impdp工

    使用exp/imp 导入导出时,需要设定NLS_LANG=

    那么使用expdp/impdp需要么

    下面截取mos上的解释说明一下


    从上面的表述来说我使用exp/imp 导入导出时是需要设定字符集的,因为它是一个客户端工具。生成的dmp文件根据客户端的字符集来定(如果你没有设置的话),这样如果导出源客户端和目标端数据库字符集不一致,imp导入就会出现乱码;而expdp/impdp工具是不依赖NLS_LANG的,它是基于源端和目标端NLS_CHARACTERSET

    展开全文
  • 在AIX(UNIX)或者LINUX系统中,导出(exp)、导入imp)Oracle数据时,导出、导入的客户端最好保持系统的字符集一致,否则再导入数据时,经常发生能正常导入问题(会出现乱码)。 在AIX中用oracle...

     

    在AIX(UNIX)或者LINUX系统中,导出(exp)、导入(imp)Oracle数据时,
    导出、导入的客户端最好保持系统的字符集一致,否则再导入数据时,经常发生不能正常导入问题(会出现乱码)。

    在AIX中用oracle用户在系统中查看系统的字符集。

    确定导出的、导入的系统字符集
      $ echo $NLS_LANG
    AMERICAN_AMERICA.ZHS16GBK 


    注释:
    增加一个表空间的数据文件
    SQL> alter tablespace PUB_NORM_SPACE
      2  add datafile '/oracle/oradata/mlog/pub_data02.dbf'
      3  size 10M autoextend on;

    来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/12778571/viewspace-611767/,如需转载,请注明出处,否则将追究法律责任。

    转载于:http://blog.itpub.net/12778571/viewspace-611767/

    展开全文
  • 所以通常当导出库和导入库的字符集不一致时,用导入库的客户端连接到导出库导出,再在本地导入。   2. 可以用以下语句判断数据表中的某一个字段是否字符编码正常。 select dump(列名) from 表名;   正常。每...
  • 我们在exp导入的时候,经常会有警告字符不一致的问题。下面来看看在imp/exp导入导出的时候,nls_lang这个参数到底应该怎么来配置。 ORACLE推荐在执行exp的时候nls_lang配置与database nls_character一致,这样不会...
  • oracle不同字符集导入导出(GBK导入UTF8) 因数据库迁移,需要将原oracle备份文件导入新的oracle数据库中,EXP导出后,...确认字符集不一样后,按如下方法解决: 说明:首先确认一下你的数据库字符集,是不是和原来的
  • 数据泵不一致导致的,比如说你用expbd导出来的 用imp导入的时候就会出现这个错误 exp导出来的用imp导入 expbd导出来的用impbd导入
  • oracle导入报错,更改数据字符集

    千次阅读 2018-05-30 15:12:46
    导入数据的时候会报错IMP-00019: ... 的值太大 (实际值: 24, 最大值: 20)有可能是导出数据和导入数据编码格式不一致,需要进修修改编码。注:修改数据库编码需要谨慎,不要影响到其他数据。更改数据库server编码1....
  • oracle IMP 数据导入

    2007-11-26 20:04:00
    在用IMP 导入数据时,提示字符集错误.这可能是由于你导出数据所用ORACLE 版本和你导入的是否一致所造成的.我在前段时间的工作中就遇到一个这种问题.导出数据所用ORACLE 版本是8.17,导入数据所用ORACLE 版本为9.20.在...
  • oracle imp/exp导入导出数据 1.检查服务端字符集 select userenv('language') from dual;...2.若目标服务端字符集不一致需修改 SQL> conn /as sysdba Connected. SQL> shutdown immediate; Database cl...
  • oracle 更改字符集

    2013-03-14 13:54:00
    服务器A字符集和服务器B字符集不一致. 服务器A exp命令导出 dmp文件后,在服务器B上 imp导入中文出现乱码. 解决问题思路:更改服务器B上面oracle 服务的字符集(实质等同于服务器A oracle的字符集). 1 查看服务器A...
  • oracle导入导出exp/impimp-00037错误

    万次阅读 2014-08-12 10:43:35
    字符集不一致;2.导出文件传输过程中遭到破坏(如ftp没有使用bin模式);3.其它原因 确认一下导入与导出的数据库的字符集类型是否一致: select * from V$NLS_PARAMETERS; NLS_NCHAR_CHARACTERSET AL
  • Oracle查看imp导出文件中字符集 我们在exp导入的时候,经常会有警告字符不一致的问题。下面来看看在imp/exp导入导出的时候,nls_lang这个参数到底应该怎么来配置。 Oracle推荐在执行exp的时候nls_lang配置与database...
  • ORACLE字符集问题

    2010-02-22 09:02:26
    这几天在接手了一个项目,客户提供了一个DMP文件与所需的表...按照IMP习惯,先创建了实例与表空间,再进行IMP FULL导入,执行时报出了字符集不一致的问题。同事在网上查了资料,发现更改这个DMP十六进制文件中的部分...
  • 我们在exp导入的时候,经常会有警告字符不一致的问题。下面来看看在imp/exp导入导出的时候,nls_lang这个参数到底应该怎么来配置。ORACLE推荐在执行exp的时候nls_lang配置与database nls_character一致,这样不会...
  • 三.... Import 把这些文件中的数据读到Oracle 数据库中,由于使用exp/imp进行数据迁移时,数据从源数据库到目标数据库的过程中有四个环节涉及到字符集,如果这四个环节的字符集不一致,将会发生字
  • IMP-00038 解决办法

    千次阅读 2020-05-11 18:44:36
    导入dmp文件,发现字符集不一致无法执行imp。报错信息: IMP-00038: Could not convert to environment character set’s handle IMP-00000: Import terminated unsuccessfully 原因分析 原以为是字符集不一致导致...
  • expdp/impdp和 exp/imp 乱码问题

    千次阅读 2018-07-05 18:16:28
    使用exp/imp 导入导出时,需要设定NLS_...生成的dmp文件根据客户端的字符集来定(如果你没有设置的话),这样如果导出源客户端和目标端数据库字符集不一致imp导入就会出现乱码;而expdp/impdp工具是不依赖NLS_LAN...
  • 00019: 由于 ORACLE 错误 12899 而拒绝行IMP-00003: 遇到 ORACLE 错误 12899ORA-12899: 列 "qmjk"."user"."uname" 的值太大 (实际值: 24, 最大值: 20)有可能是导出数据和导入数据编码格式不一致,需要进修修改编码。...
  • 导读:GBK与AL32UTF8字符不一致导致,在由ZHS16GBK字符集编码的数据库导出的DMP文件导入到由AL32UTF8字符集编码的数据库时有的表就会提示”字符过长”,导入不成功! 解决办法: 1,修改字符集编码。 2,重装...
  • oracle导出命令 exp test/test@dbname file=dbname.dmp rows=y oracle导入命令 imp test/test@company ...如果字符集不一致 可临时更改字符集,先运行如下代码,在执行导入命令 export NLS_LANG=AMERICAN_A...
  • 对于系统和数据库字符集设置不一致的问题,可能会出现多种问题.1.对数据imp/exp导出导入时,可能会有些字符出现报错,典型的报错如下(虽然对数据的影响应该不会造成影响): EXP-00091:Exporting questi...
  • 导入dmp文件需要确定一下几点 ... 例如: 如果对方导出dmp文件使用用户名与表空间不一致 则会导入时报ORA-00959:表空间不存在 ORA-01918:用户不存在...则会报IMP-00038:无法转换为环境字符集句柄 IMP-00000:未...
  • 处理IMP-00037错误

    千次阅读 2011-07-10 23:37:30
    由于工作的需要,要将10G库中的数据导出,然后导入11G库中。偷懒使用plsql工具(windows平台)导出... 在网上搜了一下有很多关于这个错误的解决方法,是由于客户端与服务端字符集不一致导致数据导入失败。 查看数...
  • exp/imp expdp/impdp乱码

    千次阅读 2015-11-04 13:39:17
    解决导入库跟导出库字符集不一致乱码问题: 1、查询导入库字符集 select userenv('language') from dual; USERENV('LANGUAGE') ---------------------------------------------------- AMERICAN_AMERICA.AL32UTF8 2...

空空如也

空空如也

1 2 3
收藏数 50
精华内容 20
关键字:

imp导入字符集不一致