导入dmp后数据库中文乱码
现象:
发现查看表详情,中文备注全部显示问号
解决方法如下:
1.查看Oracle字符集
server端字符集 SQL> select userenv(language) from dual; USERENV(LANGUAGE) AMERICAN_AMERICA.AL32UTF8
2.查看dmp文件字符集
用ue或者notepad++采用16进制打开dmp文件。我这里用的是notepad++,需要安装插件HEX-Editer
SQL> select nls_charset_name(to_number(0369,xxxx)) from dual; NLS_CHARSET_NAME(TO_NUMBER(0369,XXXX)) -------------------------------------------------------------------------------- AL32UTF8
3.查看导入dmp命令执行的机器的字符集(我这里是centos的机器)
查看字符集 [oracle@rabbitmq dump]$ echo $NLS_LANG AMERICAN_AMERICA.ZHS16GBK 发现字符集跟数据库还有dmp文件字符集都不一致,修改环境变量 export NLS_LANG=AMERICAN_AMERICA.AL32UTF8 以上语句只能暂时生效。