当前位置:  数据库>oracle

Linux 下修改Oracle 的字符集:WE8ISO8859P1 修改为 ZHS16GBK

    来源: 互联网  发布时间:2017-03-31

    本文导语: 问题描述:同事在Linux下安装的Oracle,默认的字符集没有修改,使用的是WE8ISO8859P1,不能够支持中文, 问题表现为,客户端录入的中文数据可以显示,提交之后再查询出来后中文会显示为???。问题出在oracle服务端的字符集不支持...

问题描述:同事在Linux下安装的Oracle,默认的字符集没有修改,使用的是WE8ISO8859P1,不能够支持中文,

问题表现为,客户端录入的中文数据可以显示,提交之后再查询出来后中文会显示为???。问题出在oracle服务端的字符集不支持中文导致。

可以通过:

select   userenv('language')   from   dual; 命令可以查看服务端的使用的字符集。

或者select   *   from   V$NLS_PARAMETERS;命令也可以

以及 select * from SYS.PROPS$;

确定了问题后就Google了一下,网上倒是有很多这方面的资料。可能是自己的环境和他们的不一致的原因,按照网上的那些步骤我的问题没有解决。

问题根源找到了就好解决了,参考着网上的资料自己的解决步骤如下:

总的来说有两个思路:

1、重新安装

2、修改字符集

注:第一个方法没有用,觉得重装不是我喜欢的道道,解决问题是根本。所以我选择的是第二种方式。

网上很多人说,oracle服务端安装好了之后字符集是不可以更改的,实践证明是可以修改的,至少oracle8以上的版本都是可以修改的。

我的解决步骤:

1、ssh登录,切换到oracle用户

切换用户命令:su -oracle

之后用sqlplus登录oracle,命令:

:sqlplus /nolog

:connect /as sysdba

这样就登录了。

2、更改字符集

首先 sqlplus登录后,关闭oracle数据库

1.shutdown immediate ;    
2.startup mount ;    
3.alter  system enable restricted session ;     
4.alter  system  set  JOB_QUEUE_PROCESSES=0;     
5.alter  system  set  AQ_TM_PROCESSES=0;     
6.alter   database   open  ;     
7. alter database character set INTERNAL_USE ZHS16GBK;     
8.shutdown immediate ;    
9.startup ;    







注:一开始我按照上面的步骤没有解决,因为在第7步的时候有的资料提示使用alter database character set ZHS16GBK;我试过,这个命令不行,我使用的是alter database character set INTERNAL_USE ZHS16GBK; 提示修改成功。同样,如果在startup mount 下命令提示error的话,可以尝试在startup restrict下运行第七步的命令。

以下是我的调试命令记录,大家可以参考一下,那些提示错误的命令都是执行失败的,可以不必管。

SQL> conn /as sysdba
Connected.
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup mount
ORACLE instance started.






Total System Global Area  285212672 bytes
Fixed Size                  1218992 bytes
Variable Size             104859216 bytes
Database Buffers          176160768 bytes
Redo Buffers                2973696 bytes
Database mounted.
SQL> alter system enable restricted session;





System altered.

SQL> alter system set job_queue_processes=0;

System altered.

SQL> alter system set aq_tm_processes=0;

System altered.

SQL> alter database open;

Database altered.


    
 
 

您可能感兴趣的文章:

  • linux/Centos/ubuntu下如何使用umask命令修改新建文件时的默认权限
  • 求助,linux中修改了目录dir下的某个文件,相应的dir属性中的时间会与修改目录下文件的时间一致,这是怎么实现的?
  • linux/Centos下查看和修改网卡Mac地址(ifconfig命令)
  • 我是linux初学者,我修改了/ect/fstab,结果出现登陆报错,请教大家如何修改
  • linux修改用户密码出现问题,当密码修改为2011042109时,我可以用2011042108或2011042112等只要前8位一样后面任意输入都可以登录
  • 在redhat-linux7.2下,用lilo的方式启动,当升级内核时,如何修改/etc/lilo.conf文件?有没有什么设置让系统自动修改这个文件??
  • 虚拟机上的Linux怎么修改Linux内存
  • linux 代码修改后编译
  • 怎样修改linux下网卡的MAC地址?
  • 在装了xp后再装linux,现在grub默认启动是linux,如何修改,让默认启动为xp?
  • linux命令行模式下如何修改文件内容
  • linux 修改文件内容,在线等
  • 在linux下如何修改ip地址???-调用C函数
  • ---在Linux下如何修改只读文件 ?
  • 请问如何修改红旗LINUX的网络名称和工作组?
  • Linux/CentOS/fedora下vim显示的字符编码设置 iis7站长之家
  • linux修改用户组命令..在线等
  • linux下如何修改控制台字体?
  • 使用SSH修改linux密码的问题
  • linux系统中建立一个用户专门用来修改系统时间怎么做?
  • 【请教】怎么修改linux内核参数
  • linux装的是英文的,他的默认字符集是什么字符集?
  • linux下如何查看当前配置的字符集,以及更改当前字符集(在命令行状态下)
  • LINUX7。3默认字符集下的数据在LINUX9不可见,望指点!
  • linux下安装mysql字符集转换的问题
  • 请教各位大侠如何察看和修改linux的默认字符集?
  • linux下字符集设定
  • Linux8.0 修改字符集后,再次进系统,无图形界面问题。。。求救。。
  • 关于Linux字符集的问题
  • 怎么设置linux的字符集
  • 如何在Linux(Red Hat Linux 7.2)下卸载JBuilder 6,重装??Linux系统字符集由中文更改为英文后,JBuilder支持的字体极少!!
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Linux c字符串中不可打印字符转换成16进制
  • linux c 中怎么从字符串中截取从第5为开始长4个字符的数剧?
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 请问在linux下,怎样把unicode字符转化为gbk字符,急用,谢谢
  • linux c下利用srand和rand函数生成随机字符串
  • linux里字符串开头为空字符是什么意思
  • linux下利用(cat,strings,head,sed)命令生成随机字符串
  • Linux下的C语言字符串和字符有几种类型?和Windows下区别是不是很大?
  • Linux/CentOS/fedora下vim显示的字符编码设置
  • 在linux下写一个shell:if(字符串1==“”(空) 或字符串2====“”(空))怎马写啊,急
  • linux bash shell命令:文本搜索工具grep中用于egrep和 grep -E的元字符扩展集
  • Linux字符界面下,怎么控制已经打印出的字符啊?谢谢了!!
  • Linux下C语言strstr()查找子字符串位置函数详细介绍(strstr原型、实现及用法)
  • linux下目录名或文件名是限制在256字符内吗?名称上有什么特殊要求?字符界面下能用中文吗?
  • linux bash shell命令:文本搜索工具grep正则表达式元字符集(基本集)
  • 请问:linux下C/C++编程,怎样把含有中英文及数字其他字符的字符串,转化成utf-8编码,又怎样将其转换回来。iconv好像不支持混合?
  • Linux c语言 如何统计utf-8编码的包含中英文和各种符号的字符串中各个字符的个数
  • linux文本的末位字符是什么
  • linux下做C++ 字符编码的问题
  • linux下如何改变字体设置使其能看懂windows下的字符。
  • linux下如何在二进制文件中查找字符串string
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • secureCRT下Linux终端汉字乱码解决方法
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • linux命令大全详细分类介绍及常用linux命令文档手册下载
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux Kernel 'sctp_v6_xmit()'函数信息泄露漏洞
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3