AMERICAN_AMERICA.WE8ISO8859P1,这个字符编码是西欧字符编码,对应于.Net的就是iso-8859-1字符编码,所以只需要改到系统的默认字符编码就行了.

解决方法:

(1) 服务器端重新安装ORACLE

  在重新安装ORACLE 时选择与原卸出数据一致的字符集(本例为US7ASCII)。

  加载原卸出的数据。

  这种情况仅仅使用于空库和具有同一种字符集的数据。

(2)

写一个函数:

代码如下 复制代码
/** <summary>
/// 将西欧字符编码转换成GB2312
/// </summary>
/// <param name="s"></param>
/// <returns></returns>
public static string Convert8859P1ToGB2312(string s)
{
return System.Text.Encoding.Default.GetString(System.Text.Encoding.GetEncoding("iso-8859-1").GetBytes(s));
}

(3)强行修改服务器端ORACLE当前字符集

在用imp命令加载数据前,先在客户端用sql*plus登录system DBA用户,执行下列SQL语句进行当前ORACLE数据库字符集修改:

代码如下 复制代码
SQL > create database character set US7ASCII
  * create database character set US7ASCII
  ERROR at line 1:
  ORA-01031: insufficient privileges

(3)显示中文乱码

在Redhat上安装Oracle 10g没有设定字符集,采用的是操作系统默认字符集:WE8ISO8859P1,将字符集修改为:ZHS16GBK。由于过程不可逆,首先需要备份数据库。
1.数据库全备

代码如下 复制代码
2.查询当前字符集
SQL> select * from nls_database_parameters where parameter='NLS_CHARACTERSET';
PARAMETER VALUE
---------------------------------------- ----------------------------------------
NLS_CHARACTERSET WE8ISO8859P1

3.关闭数据库
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.

4.启动数据库到mount状态

SQL> startup mount
ORACLE instance started.
Total System Global Area 205520896 bytes
Fixed Size 1266608 bytes
Variable Size 100666448 bytes
Database Buffers 100663296 bytes
Redo Buffers 2924544 bytes
Database mounted.

5.限制session

SQL> alter system enable restricted session(www.111cn.net);
System altered.

6.查询相关参数并修改

SQL> show parameter job_queue_processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
job_queue_processes integer 10

SQL> show parameter aq_tm_processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 0

SQL> alter system set job_queue_processes=0;
System altered.

7.打开数据库

SQL> alter database open;
Database altered.

8.修改字符集

SQL> alter database character set ZHS16GBK;
alter database character set ZHS16GBK
*
ERROR at line 1:
ORA-12712: new character set must be a superset of old character set

出现错误提示,新字符集必须是老字符集的超集,也就原来字符集是新字符集的子集,可以再Oracle官方文档上查询字符集包含关系。下面使用Oracle内部命令internal_use,跳过超集检查,生产环境不建议使用此方法。

SQL> alter database character set internal_use ZHS16GBK;
Database altered.

9.查询当前字符集
SQL> select * from nls_database_parameters where parameter='NLS_CHARACTERSET';
PARAMETER VALUE
---------------------------------------- ----------------------------------------
NLS_CHARACTERSET ZHS16GBK

10.关闭数据库

SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.

11.启动数据库到mount状态

SQL> startup mount
ORACLE instance started.
Total System Global Area 205520896 bytes
Fixed Size 1266608 bytes
Variable Size 100666448 bytes
Database Buffers 100663296 bytes
Redo Buffers 2924544 bytes
Database mounted.

12.将相关参数改回原来值

SQL> alter system set job_queue_processes=10;
System altered.

13.打开数据库

SQL> alter database open;
Database altered.

from:http://www.111cn.net/database/Oracle/45120.htm

Oracle中文乱码解决办法总结相关推荐

  1. pycharm 运行控制台中文乱码解决办法

    pycharm 运行控制台中文乱码解决办法

  2. navicat for mysql 显示中文乱码解决办法

    navicat for mysql 显示中文乱码解决办法   最近遇到一个问题,用navicat for mysql 打开数据库时全都显示的是乱码(在用程序代码插入数据之前确保字符不是乱码),遇到问题 ...

  3. NetBeans中文乱码解决办法

    首先来看看网上的一篇文章:http://it.dengchao.org/neatbeans-problem-fedora/linux/ 在Windows和Linux(Fedora/Ubuntu/Red ...

  4. windows下git bash中文乱码解决办法

    一.解决办法1:(直接上图) 1.在git bash下,右键 出现下图,选择options: 2.选择"Text" 3.将"Character set"设置为 ...

  5. linux oracle查询乱码问题,linux中oracle中文乱码解决方法

    乱码问题的根源是字符集的修改,下面我们来看一下linux中oracle中文乱码解决方法. 查看客户端的语言编码设置: 配置文件中的配置: cat ~/.bash_profile 注意修改配置信息:ex ...

  6. java控制台打印输出 中文乱码 解决办法

    java控制台打印输出 中文乱码 解决办法 问题:IDEA控制台打印时出现中文乱码 原因:java资源的编码和ideal的不一致 解决办法: 第一步 1:打开intelliidea安装路径,Intel ...

  7. Web前端——VScode打开html文件中文乱码解决办法

    VScode打开html文件中文乱码解决办法 1.打开VScode后,依次点击 文件 >> 首选项 >> 设置 2.打开设置后,依次点击 文本编辑器 >> 文件(或 ...

  8. php接受get参数乱码,如何解决php get 参数乱码问题,php中文乱码解决办法

    如何解决php get 参数乱码问题如何解决php参数乱码的问题,乱码php获取参数的解决方案:1.使用"iconv ('GB 2312 ',' UTF-8 ',$龚辉):"解决乱 ...

  9. Qt中文乱码解决办法

    目录 一.解决方法: 1. QT4版本 2. QT5版本 二.QString 为什么会乱码呢 三.tr的使用 一.解决方法: 1. QT4版本 中文乱码解决办法是在main.cpp文件加入: #inc ...

最新文章

  1. JS Uncaught SyntaxError:Unexpected identifier异常报错原因及其解决方法
  2. 分析JDK源码 | Java Object
  3. handlerinterceptoradapter 获取请求参数_SSM框架防止重复请求
  4. javascript 声明变量var、let、const详解及示例
  5. mysql8 修改密码_sysbench压测软件连接mysql8失败案例分析
  6. orgchart php,最需要的时候遇见你OrgChart
  7. [设计模式-行为型]状态模式(State)
  8. 帆软报表-通过代码来创建一个模板文件
  9. 松弛法(relaxation)
  10. jupyter notebook 修改默认文件夹
  11. Atitit ocr的艺术 艾提拉著 目录 1. OCR可以说是一门非常“古老”的技术,在上世纪50年代到90年代, 1 1.1. 场景文字识别技术(Scene Text Recognition,
  12. 数值计算(四)——插值法(3)Hermite插值法(补充)
  13. 快手短视频广告投放一年需要多少钱 快手信息流广告怎么样收费模式
  14. HTML指南针源码zip,指南针指标公式源码
  15. 【LuoguP2466】[SDOI2008] Sue的小球
  16. Combined Margin loss人脸识别训练笔记
  17. Python 读取文件夹下的Excel文件导入到数据库
  18. 条码软件批量打印标签 连接Excel方式
  19. 全国计算机四级之网络工程师知识点(五)
  20. bootstrap-table固定表头固定列

热门文章

  1. 精通SERV-U配置文件
  2. Diomidis Spinellis:有效的调试
  3. MySQL集群系列2:通过keepalived实现双主集群读写分离
  4. 线程池的一些疑问和解答
  5. OpenJudge/Poj 2001 Shortest Prefixes
  6. Gson.toJson()时内存溢出StackOverflowError
  7. 在C#中SendMessage和PostMessage的参数传递
  8. 三星在研发VR一体机?眼动追踪公司曝出原型机
  9. Linux多台服务器共用密钥ssh自动登陆
  10. php跨域cookie共享使用方法