当前位置: 首页 > news >正文

Oracle中文显示???????解决办法

项目场景:

Oracleoracle中文显示???解决办法

问题描述

在这里插入图片描述

原因分析:

Oracle中文显示???通常是由于字符集不匹配或者编码问题导致的。当数据库中的数据使用的是某种字符集,而客户端或者应用程序使用的是另一种字符集时,就会出现中文显示乱码的情况。

另外,如果数据库中的数据本身就是损坏的或者不完整的,也有可能导致中文显示乱码的问题。

总的来说,中文显示乱码的原因主要包括字符集不匹配、编码问题、数据损坏等。


解决方案:

1、不同解决思路

  1. 修改NLS_LANG环境变量:将NLS_LANG环境变量设置为正确的字符集,例如:NLS_LANG=AMERICAN_AMERICA.ZHS16GBK。

  2. 修改Oracle客户端的字符集:在Oracle客户端中,可以通过修改NLS_LANG参数来设置字符集,例如:ALTER SESSION SET NLS_LANG=AMERICAN_AMERICA.ZHS16GBK。

  3. 修改数据库的字符集:如果数据库的字符集不是UTF-8或者GBK,可以考虑修改数据库的字符集。

  4. 使用Unicode字符集:Unicode字符集支持多种语言,包括中文,可以解决中文乱码问题。

  5. 使用Java程序连接Oracle:如果使用Java程序连接Oracle,可以在连接Oracle时指定字符集,例如:jdbc:oracle:thin:@localhost:1521:orcl?useUnicode=true&characterEncoding=UTF-8。

  6. 使用PL/SQL Developer等工具:一些Oracle数据库管理工具支持中文显示,例如PL/SQL Developer,可以在工具的设置中修改字符集。

2、具体解决过程

  1. 查看数据库字符集select userenv('language') from dual;

    SQL> select userenv('language') from dual;USERENV('LANGUAGE')
    ----------------------------------------------------
    AMERICAN_AMERICA.ZHS16GBKSQL> 
    
  2. 查询系统字符集locale

    [oracle@localhost ~]$ locale
    LANG=en_US.UTF-8
    LC_CTYPE="en_US.UTF-8"
    LC_NUMERIC="en_US.UTF-8"
    LC_TIME="en_US.UTF-8"
    LC_COLLATE="en_US.UTF-8"
    LC_MONETARY="en_US.UTF-8"
    LC_MESSAGES="en_US.UTF-8"
    LC_PAPER="en_US.UTF-8"
    LC_NAME="en_US.UTF-8"
    LC_ADDRESS="en_US.UTF-8"
    LC_TELEPHONE="en_US.UTF-8"
    LC_MEASUREMENT="en_US.UTF-8"
    LC_IDENTIFICATION="en_US.UTF-8"
    LC_ALL=
    [oracle@localhost ~]$ 
    
  3. 将数据库字符集修改为与系统字符集一致(也可修改系统字符集与数据库字符集一致)

    SQL> shutdown immediate
    SQL> startup nomount
    SQL> alter database mount exclusive;           //装载数据为专用的高级模式;
    SQL> alter system enable restricted session;   //启用受限制的session模式
    SQL> alter system set job_queue_processes=0;   //'maximum number of job queue slave processes' 设置工作队列的最大进程数为0
    SQL> alter system set aq_tm_processes=0;
    SQL> alter database open;
    SQL> alter database character set internal_use utf8;;  // 设置为自己所需字符集即可
    SQL> shutdown immediate
    SQL> startup
    

    注意:已经存在的数据,在修改了字符集之后还是会显示为乱码,只有新插入的数值才会生效

http://www.lryc.cn/news/241319.html

相关文章:

  • Java查询数据放入word模板中并在前端导出下载
  • HarmonyOS ArkTS 应用添加弹窗(八)
  • 排序算法-----快速排序(非递归实现)
  • el-input限制输入整数等分析
  • 医院手术麻醉信息系统全套源码,自主版权,支持二次开发
  • canvas扩展001:利用fabric绘制图形,可以平移,旋转,放缩
  • 什么是机器学习
  • 电子桌牌如何赋能数字化会务?以深圳程序员节为例。
  • 打包和部署Java应用程序:Maven和Shell脚本的实用方法
  • Windows Python3安装salt模块失败处理
  • RabbitMQ 消息队列编程
  • 基于安卓android微信小程序的个人管理小程序
  • 免费图书教材配套资料:Spark大数据技术与应用(第2版)
  • SecureCRT9汉化版安装
  • 【VSCode】VSCode 使用
  • 【ARM 嵌入式 编译系列 2.2 -- 如何在Makefile 中添加编译时间 | 编译作者| 编译 git id】
  • 海康威视监控相机的SDK与opencv调用(非工业相机)
  • VUE项目部署过程中遇到的错误:POST http://124.60.11.183:9090/test/login 405 (Not Allowed)
  • MongoDB——索引(单索引,复合索引,索引创建、使用)
  • ebpf实战(一)-------监控udp延迟
  • 中西部各省市翻译协会、公关协会会长金秋圆桌会议圆满结束
  • 极盾故事|“五步”构建某三甲医院数据安全管理集成平台
  • 【开题报告】基于uni-app的恋爱打卡app的设计与实现
  • Python 2.7 在 Debian 服务器上获取 URL 时的 SSL 验证失败问题与解决方案
  • 导出文件到指定路径??
  • 腾讯微服务平台TSF学习笔记(二)--如何使用spring cloud zuul实现线上流量复制
  • React自定义Hook之useRequest
  • 【LeetCode】挑战100天 Day13(热题+面试经典150题)
  • Android 11.0 SystemUI 去掉状态栏wifi流量上下行图标功能实现
  • 掌握Net User命令:轻松创建、修改、删除和查看本地用户帐户