shell中乱码的问题

    今天遇到自己写的shell scrip.执行后,查看数据库后发现:要更新数据库字段为繁体中文的变成乱码。追根溯源,vi了一下shell script,原来在用ftp上传到Linux系统的服务器上就已经是16进制的符号了。

    于是开始搜索如何设置linux字符集,找到用locale命令查看当前OS的字符集。查到该服务器是使用默认字符集。于是:

      export LC_ALL=zh_CN.UTF-8 

      因为打开putty终端的设置时发现没有 big-5的字符集,所以直接选择UTF-8,保险一点了。

     然后在本地重新编辑原 shell script, 设置文件的字符集为UTF-8格式,然后输入繁体字,保存。

     重新传到 linux机后,cat ,文件显示正常的繁体字体。

    run : sh update_XXXX.sh

    查看数据库,数据库中内容应该为繁体字的表的字段,仍为乱码。

    于是想到应该是数据库设置字符集与linux OS 字符集不一致造成的,于是用切换到oracle 用户,进入$ORACLE_HOME/jre/1.4.2/lib目录,查看font.properties文件,发现该文件

设置字符集为ISO-8859-1;将该文件做备份,mv font.properties.zh_CN_UTF8  font.properties.基本算解决了。

 

      参考文章:http://hi.baidu.com/ykdhulzovpbchpd/item/deed7ff35c26450dd99e7230(Linux中通过locale来设置字符集)

                       http://mibzsl.bokee.com/3253356.html(ORACLE字符集的设置)

   

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值