sqlplus执行脚本 乱码_linux环境使用sqlplus执行SQL脚本中文乱码处理

某组服务器上的sqlplus在执行定时更新SQL脚本时,中文出现乱码。一开始找错了问题方向:从SQL更新脚本处理的源头开始,首先对windows下的编辑器生成的脚本文件做各种编码的尝试,然后又在vi编辑器里面进行字符编码(encoding)与文件编码(fileencoding)的各种调试。后来发现转了圈,不过并不算浪费时间,最起码对字符编码多了一些了解。

我是通过如下的方法解决sqlplus执行SQL脚本出现的中文乱码问题:

1.生产环境中的字符集全是UTF8,所以对于上传至服务器上的脚本都以'UTF8 without BOM'保存

2.查看Oracle的字符集编码:

SQL> select userenv('language') from dual;

USERENV('LANGUAGE')

----------------------------------------------------

AMERICAN_AMERICA.AL32UTF8

SQL>

3.修改Linux的NLS_LANG环境变量,修改Oracle指定的Linux用户下面“.base_profile”文件,加入如下:

export NLS_LANG="AMERICAN_AMERICA.AL32UTF8"

4.执行.bash_profile,使环境变量设置生效,查看其值:

$ echo $NLS_LANG

AMERICAN_AMERICA.AL32UTF8

至此,此次中文乱码的问题得已解决。

推荐一篇文章,是介绍Vim 中与编码有关的四个选项的,如不是很清楚它们之间关系的可以访问以下网址读一下:

参考来源:

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

打赏
文章很值,打赏犒劳作者一下
表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
相关推荐
©️2020 CSDN 皮肤主题: 深蓝海洋 设计师:CSDN官方博客 返回首页

打赏

weixin_39668496

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者