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

plsql查询Oracle数据库发现有的数据是乱码

原因:Oracle数据库字符集和plsql客户端所使用的字符集不一致。
查询时,可能因为解码问题导致解出错误的字符。
也可能插入时就没有使用正确的字符集,解码时用utf-8自然也无法解出正确的字符。

环境变量 NLS_LANG 定义了客户端使用的语言、地域和字符集。这个变量影响客户端如何发送和接收数据。
定义一个系统环境变量:环境变变量名:NLS_LANG 环境变量值:AMERICAN_AMERICA.AL32UTF8
保证数据库字符集和这个一致。

转换过程:
客户端发送数据:客户端应用程序按照 NLS_LANG 指定的字符集将数据发送给数据库。
数据传输:数据通过网络传输到数据库服务器。
数据接收与转换:数据库接收到数据后,会将其从客户端字符集转换为数据库字符集。
存储数据:转换后的数据以数据库字符集存储在数据库中。

详细流程:
比如我们要插入数据 “一二三四五六” 时的转换流程。假设以下环境设置:

  • 客户端字符集AL32UTF8(由 NLS_LANG 指定)
  • 数据库字符集ZHS16GBK(由 NLS_CHARACTERSET 指定)

1. 客户端发送数据

  • 数据:“一二三四五六”
  • 客户端字符集AL32UTF8

客户端应用程序会将数据 “一二三四五六” 按照 AL32UTF8 字符集编码。AL32UTF8 是 UTF-8 字符集的一种,支持几乎所有的 Unicode 字符。

编码示例:

  • “一” 的 UTF-8 编码是 E4B880
  • “二” 的 UTF-8 编码是 E4B881
  • “三” 的 UTF-8 编码是 E4B882
  • “四” 的 UTF-8 编码是 E4B883
  • “五” 的 UTF-8 编码是 E4B884
  • “六” 的 UTF-8 编码是 E4B885

所以,数据 “一二三四五六” 在 AL32UTF8 字符集下的编码是:

E4B880 E4B881 E4B882 E4B883 E4B884 E4B885

2. 数据传输

数据通过网络以字节流的形式传输到数据库服务器。

3. 数据接收与转换

Oracle 数据库接收到数据后,会读取客户端的 NLS_LANG 设置,识别出客户端使用的字符集是 AL32UTF8。
会先将数据E4B880 E4B881 E4B882 E4B883 E4B884 E4B885使用指定的字符集(AL32UTF8)进行解码,解码成字符"一二三四五六",之后再将其使用 ZHS16GBK进行编码。ZHS16GBK 是 GBK 字符集的一种,支持简体中文字符。(实际上解码并没有解成一二三四五六,解码和编码是一步完成的,这么写是为了方便理解)

转换过程:

  • 输入数据E4B880 E4B881 E4B882 E4B883 E4B884 E4B885
  • 目标字符集ZHS16GBK

转换示例:

  • “一” 的 GBK 编码是 D2BB
  • “二” 的 GBK 编码是 B6E0
  • “三” 的 GBK 编码是 C6DF
  • “四” 的 GBK 编码是 CBCE
  • “五” 的 GBK 编码是 D2D5
  • “六” 的 GBK 编码是 D2D6

所以,数据 “一二三四五六” 在 ZHS16GBK 字符集下的编码是:

D2BB B6E0 C6DF CBCE D2D5 D2D6

4. 存储数据

最终将转换后的数据D2BB B6E0 C6DF CBCE D2D5 D2D6存储在数据库中。

总结

  • 客户端发送数据:数据 “一二三四五六” 以 AL32UTF8 字符集编码,即 E4B880 E4B881 E4B882 E4B883 E4B884 E4B885
  • 数据传输:数据通过网络传输到数据库服务器。
  • 数据接收与转换:数据库接收到数据后,将其从 AL32UTF8 转换为 ZHS16GBK,即 D2BB B6E0 C6DF CBCE D2D5 D2D6
  • 存储数据:转换后的数据以 ZHS16GBK 字符集存储在数据库中。

http://www.kler.cn/a/354054.html

相关文章:

  • IPsec VPN配置实验(固定地址)
  • 嵌入式硬件杂谈(七)IGBT MOS管 三极管应用场景与区别
  • 基于aspose.words组件的word bytes转pdf bytes,去除水印和解决linux中文乱码问题
  • 代码随想录Day51 99. 岛屿数量,99. 岛屿数量,100. 岛屿的最大面积。
  • 【已解决】pyinstaller打包ico图片报错:OSError: [WinError 225] 无法成功完成操作,因为文件包含病毒或潜在的垃圾软件。
  • Java爬虫技术:按关键字搜索VIP商品详情
  • Pr 音频效果快速参考(合集 · 2025版)
  • 基于Leaflet和SpringBoot的全球国家综合检索WebGIS可视化
  • 阿里 C++面试,算法题没做出来,,,
  • 基于STM32的智能物联网家用机器人设计
  • 组串式储能变流升压一体机
  • Field injection is not recommended – Spring IOC
  • AutoCompleteTextView
  • 【SuperHotSwap】IDEA零配置热更新插件升级
  • 【设计模式】深入理解Python中的原型设计模式
  • 【电商购物管理系统】Python+Django网页界面平台+商品管理+数据库
  • Unity3D模型消融方法(二)
  • vue中如何自定义Form表单rules校验方法(手机号/座机号、身份证号/社会统一信代码校验,支持多个,以英文逗号分隔)
  • Scala的filter函数
  • 网络基础一
  • 利用高德API获取整个城市的公交路线并可视化(五)
  • Promise.race()
  • 【python爬虫】携程旅行景点游客数据分析与可视化
  • Biotin-PEG-COOH 羧基-聚乙二醇-生物素的应用 蛋白质纯化 细胞标记
  • 如何将两个视频连接成一个?共有6个方法
  • 集成电路公司进销存系统生成合同——未来之窗行业应用跨平台架构