oracle报错信息乱码,Oracle乱码的问题

1.sql脚本直接能执行但是以sql文件不能执行

sql正常,由txt转换为sql文件后,数据库执行报错,解决办法是将sql文件中数据取出放到新文件中,新文件保存时直接以sql格式保存。

2.乱码问题

1.如果导入到plsql中显示乱码,首先查看sql的存储格式,修改成utf-8

2.查看服务器端编码—

select userenv('language') from dual;

我实际查到的结果为: SIMPLIFIED CHINESE_CHINA.ZHS16GBK

(AMERICAN_AMERICA.AL32UTF8)这个也是常用的  AMERICAN_AMERICA.ZHS16GBK

18b04da468f96998a72e4016b59ca307.png

如果不正确的话设置方法:----在oracle的数据上去执行的

[oracle@ORACLE ~]$ sqlplus /nolog

conn /as sysdba;

select userenv('language') from dual;

SHUTDOWN IMMEDIATE

STARTUP MOUNT

ALTER SYSTEM ENABLE RESTRICTED SESSION;

ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;

ALTER SYSTEM SET AQ_TM_PROCESSES=0;

ALTER DATABASE OPEN;

ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK;

SHUTDOWN IMMEDIATE;

STARTUP;

查看一下是否修改过来

select userenv('language') from dual;

3.客户端

执行语句 select * from V$NLS_PARAMETERS

查看第一行中PARAMETER项中为NLS_LANGUAGE 对应的VALUE项中是否和第一步得到的值一样。

或者途中的NLS_LANGUAGE和NLS_CHARACTERSET中的value的值加到一起和服务器中额编码是否一致。

如果不是,需要设置环境变量.或者修改注册表 regedit

NLS_LANG

否则PLSQL客户端使用的编码和服务器端编码不一致,插入中文时就会出现乱码.

2.Unix/Linux环境,查看和修改NLS_LANG变量的方法

1)查看方法,在oracle用户下使用env命令获得系统的环境变量列表,然后使用grep命令定位到“NLS_LANG”内容

$ env | grep NLS_LANG

NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

2)修改方法:使用export命令设置该环境变量

$ NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

$ export NLS_LANG

很全的知识

https://www.2cto.com/database/201111/111388.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值