Oracle数据库汉字乱码问题

[复制链接]
查看11 | 回复1 | 2012-5-16 15:28:38 | 显示全部楼层 |阅读模式
最近在学习Oracle数据库中遇到汉字乱码的问题,珠海甲骨文(http://www.oracle-zh.com)的小编查找了一下网上的内容后,原因有以下方面:

  1. 1服务器 指定字符集与客户字符集不同,而与加载数据字符集一致。
  这种情况是最常见的,只要把客户端的字符集设置正确即可,解决办法见2.1.
  1. 2服务器指定字符集与客户字符集相同,与加载数据字符集不一致。
  这类问题一般发生在ORACLE版本升级或重新安装系统时选择了与原来服务器端不同的字符集,而恢复加载的备份数据仍是按原字符集卸出的场合,以及加载从其它使用不同字符集的ORACLE数据库卸出的数据的情况。这两种情况中,不管服务器端和客户端字符集是否一致都无法显示汉字。解决办法见2.2.
  1.3服务器 指定字符集与客户字符集不同,与输入数据字符集不一致。
  这种情况是在客户端与服务器端字符集不一致时,从客户端输入了汉字信息。输入的这些信息即便是把客户端字符集更改正确,也无法显示汉字。解决办法见2.3.

  下面是这些问题的解决办法
  2.解决办法
  下面将分别对上述三种情况给出解决办法。为了叙述方便,假设客户端使用WINDOWS95/98环境,并已成功地配置了TCP/IP协议,安装了ORACLE的sql*net,sql*pluse产品。
  2.1 设置客户端字符集与服务器端字符集一致
  假设当前服务器端使用US7ASCII字符集。
  (1)查看服务器端字符集
  通过客户端或服务器端的sql*plus登录ORACLE的一个合法用户,执行下列SQL语句:
  SQL > select * from V$NLS_PARAMETERS
  或者
  SQL > select * from NLS_DATABASE_PARAMETERS;
  parameter value
  NLS_LANGUAGE AMERICAN
  NLS_TERRITORY AMERICA
  … …
  NLS_CHARACTERSET US7ASCII
  NLS_SORT BINARY
  NLS_NCHAR_CHARACTERSET US7ASCII
  从上述列表信息中可看出服务器端ORACLE数据库的字符集为 'US7ASCII '.
  ===可以使用
  export NLS_LANG=“SIMPLIFIED CHINESE_CHINA.ZHS16GBK”
  这只能在会话内生效,可以加到 oracle用户home目录/.bash_profile 内,是修改永久生效。
  (2)按照服务器端字符集对客户端进行配置
  配置方法有两种:
  安装ORACLE的客户端软件时指定
  在安装ORACLE的客户端产品软件时,选择与ORACLE服务端一致的字符集(本例为US7ASCII)即可。
  修改注册信息的方法
  希望Oracle汉字乱码之我见能为读者带来一定帮助。


回复

使用道具 举报

千问 | 2012-5-16 15:28:38 | 显示全部楼层
做广告也要拿一些牛点的东东来展示一下啊。这个字符集老调重弹了吧!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

主题

0

回帖

4882万

积分

论坛元老

Rank: 8Rank: 8

积分
48824836
热门排行