oracle 导入sql文件 汉字乱码_Oracle导入汉字乱码问题处理实例

现象描述

新部署一套环境,需要将预置的数据导入数据库中,以SQL文件的形式导入。

但是导入的结果在检查时发现汉字全都是乱码,如下图:

而且在导入数据的时候也发现很多问题:

问题解决

首先肯定这是因为字符集的原因导致的,因为Oracle所有涉及到汉字乱码的问题都能归结为字符集的问题。

接下来检查Oracle自己的字符集:

这里有两个几个重要的信息:NLS_LANGUAGE

NLS_TERRITORY

NLS_CHRACTERSET

接下来在Linux的terminal里查询NLS_LANG这个环境变量:

echo $NLS_LANG

发现结果是空,此时需要把这个值修改成上面Oracle查询出来的值,其具体要求是:

export NLS_LANG=NLS_LANGUAGE_NLS_TERRITORY.NLS_CHRACTERSET

具体到这个例子里就应该是这样的命令:

export NLS_LANG='AMERICAN_AMERICA.UTF8'

需要注意的是,这个设置是session级别的

现在可以重复刚才导入数据的过程,就会正常的导入数据,并能查询出正确的结果了。

如果此时在Plsql Developer或者SQLPLUS中查询出来的汉字还是乱码,就需要检查一下LANG变量是否正确设置:

export LANG=en_US.UTF-8

一般情况下,这样设置,就能让保存为UTF8格式的中文文本被正确识别并导入。

结束

之前写过一个MySQL导入的案例:有财君:你所看到的,还真不一定是真实的​zhuanlan.zhihu.com

生活在非英语国家,有时候这些问题是难以避免的,看见汉字,一定要谨慎。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
导入一个Oracle数据库的.dmp文件,您可以按照以下步骤进行操作: 1. 确保您已经安装了Oracle数据库,并且具有相应的权限来执行导入操作。 2. 打开命令行终端或者SQL*Plus工具,并使用管理员账户登录到Oracle数据库。 3. 确保.dmp文件已经位于您可以访问的位置。如果需要,将.dmp文件复制到合适的位置。 4. 在命令行终端或者SQL*Plus中,使用以下命令来导入.dmp文件: ``` impdp 用户名/密码@数据库实例 DIRECTORY=目录对象 DUMPFILE=导入文件名.dmp LOGFILE=日志文件名.log ``` 其中,用户名/密码是具有导入权限的用户的凭据,数据库实例是要导入到的数据库实例的名称,目录对象是指向.dmp文件所在目录的Oracle目录对象,导入文件名.dmp是要导入的.dmp文件名称,日志文件名.log是导入过程的日志文件名称。 5. 执行上述命令后,Oracle将开始导入过程,并将输出日志信息到指定的日志文件中。请耐心等待导入过程完成。 6. 导入完成后,您可以通过查询相应的表或者执行其他操作来验证数据是否成功导入到数据库中。 请注意,在执行导入操作之前,请确保您已经备份了现有的数据库,以防止意外情况发生。另外,导入过程可能需要一些时间,具体时间取决于.dmp文件的大小和系统性能。 以上是导入一个Oracle数据库的.dmp文件的详细步骤,希望对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值