Oracle EBS在编码方式为AL32UTF8时的注意事项
现如今的EBS系统中,为了推进国际化的进程,以及系统向全球化的扩展,在Oracle数据库的编码方式上渐渐从支持中国本土简体中文的ZHS16GBK转向了更趋于国际化的AL32UTF8编码方式。但随之而来在中国就会产生很多问题,例如:
- 其他的外围系统仍然使用简体中文GB2312/ZHS16GBK编码,在接口文件传输时由于编码不一致而产生乱码问题
- Excel不兼容,简体中文版的Excel在读取文本文件时采用的是默认的简体中文编码方式打开,所以已UTF-8编码的文件(如CSV文件)在打开时会产生乱码问题
所以在中国的IT系统,一旦选择采用了AL32UTF8的国际化编码方式之后,了解一些编码方式的区别以及常见问题的解决方法是非常必要的。
编码方式
这里就不深入讨论编码的知识了,简单阐述一下二者的不同之处,见如下表格:
| 编码方式 | 隶属于 | 一个中文字符所占字节 | 说明 |
| ZHS16GBK | ANSI | 2 | 与所有隶属于ANSI的编码兼容 |
| AL32UTF8 | Unicode | 3 | 与所有隶属于Unicode的编码兼容 |
所以二者属于两套字符集衍生出来的,所以并不兼容,需要显示的进行转码才能正常显示。
PLSQL/SQL客户端的配置
客户端配置需要考虑Oracle Client的所支持的语言和注册表中NLS_LANG键值的设置。
- Oracle客户端需要安装兼容64为的32位客户端:win32_11gR2_client,具体请从Oracle官方网站上进行下载;
- NLS_LANG的键值需要设置成“AMERICAN_AMERICA.AL32UTF8” 或者 “SIMPLIFIED CHINESE_CHINA.AL32UTF8”
EBS基础设置
请确保一下表格中列示的配置文件已经设置了正确的值:
| 配置文件名称 | 设置层 | 配置文件值 |
| FND: NATIVE CLIENT ENCODING | SITE | UTF8 |
| ICX: Client IANA Encoding | SITE | Unicode (UTF-8) |
当为文本类型输出格式设置新的打开方式时,请确保“Allow Native Client Encoding”已经勾选。

报表类程序(HTML, HTML as EXCEL, PDF)
对于HTML的报表,需要在HTML头上指定encoding为utf-8:<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
另外编码方式可以用一下代码动态从系统中获取:
l_encoding := fnd_profile.value('ICX_CLIENT_IANA_ENCODING');
对于PDF输出类报表,以上获取编码方式的方法仍然适用,并填充值XML的头部:
<?xml version="1.0" encoding="utf-8"?>
另外,如果报表输出的中文全部显示成问号“?”,那么这种情况并不是编码方式导致的,而是服务器上缺失了必要的字体文件,在后台运行如下脚本复制字体文件到指定目录下:
#!/bin/sh
cp $FND_TOP/resource/ALBAN*.ttf $AF_JRE_TOP/lib/fonts

文件读写及外部接口兼容
1. 文件输出
对于从Oracle生成并输出的文本文件,默认的编码方式肯定是UTF-8(无BOM)的。所以一旦目标系统的编码方式是简体中文的话,那么转码的步骤一定是必须的。我们可以从两个阶段入手进行转码。
第一个阶段是在每一批写入文件的数据在写入文件之前强制利用CONVERT函数进行转码,如:
l_converted_str := CONVERT('你好', 'ZHS32GB18030');
第二个阶段是就是在文件生成之后,利用相对高级的文本编辑器,如Notepad++,对文件进行转码UTF-8 -> ANSI
2. 文件读取
与文件类似,只不过只能利用文本编辑器提前转码之后方能被Oracle处理。
Excel文件输出和Export导出
utf-8格式的csv或分割符文件在excel打开会出现乱码的情况:

utf-8格式的文本文件
利用文本编辑器进行转码后方能正确显示:

ansi格式的文件
总结
1. 检查配置文件和View Options是否设置正确
2. HTML格式报表记得要动态从系统中获取encoding
3. PDF报表记得安装字体
4. 输出到外部的文件需要进行必要转码操作(convert函数或文本编辑器)
Oracle EBS在编码方式为AL32UTF8时的注意事项的更多相关文章
- Oracle EBS 从Web界面进入责任时,提示不存在可用的有效责任
Oracle EBS 从Web界面进入责任时,提示不存在可用的有效责任 每次在Web界面,点击某一责任的功能时,弹出Form.会提示错误:对不起,不存在可用的有效责任. ...
- Oracle LPAD/RPAD函数在处理中文时的注意事项
首先看下Oracle官方对函数的定义: The RPAD function returns an expression, right-padded to a specified length with ...
- Oracle EBS Form 发布到Server端的注意事项
前段时间在本地XP系统上测试了一些整合javabean的Form例子,想着发布到服务器段去看看能否运行正常,一开始以为会和本地XP系统一样,部署到相关的目录下进行一些配置就可以了,但实际过程却和想象的 ...
- oracle 使用occi方式插入数据时中文乱码
这个是由于数据库的编码格式和我们输入的编码格式不一致导致的. 我们使用c++插入数据时数据库的中文显示??(即乱码),但同样的数据使用navicat进行插入却显示正常. 因此,问题并不是处在服务器端的 ...
- Form表单发送到服务器时的编码方式
---恢复内容开始--- 表单中的表单中enctype是设置表单的MIME编码. 所谓MIME编码,是指当服务器传送数据给客户端时,必须指定这个文件是什么类型,才能方便客户端调用相应的应用软件来打开该 ...
- setlocale(LC_ALL, ""); 取值为空字符串" "(注意,不是NULL),则locale与本地环境所使用的编码方式相同(在本地化时,应该很有用);
在C运行库提供的多字节字符-宽字符转换函数:mbstowcs()/wcstombs()中,需要用到全局变量locale( locale encoding ),以指定多字节字符的编码类型 1. 功能: ...
- 为什么一定要调用 setlocale 呢? 因为在 C/C++ 语言标准中定义了其运行时的字符集环境为 "C" ,也就是 ASCII 字符集的一个子集。使用setlocal改变整个应用程序的字符集编码方式(wcstombs使用前要设置 setlocale (LC_ALL, "chs"); )
setlocale 配置地域化信息. 语法: string setlocale(string category, string locale); 返回值: 字符串 函数种类: 操作系统与环境 内容 ...
- python爬虫时,解决编码方式问题的万能钥匙(uicode,utf8,gbk......)
转载 原文:https://blog.csdn.net/xiongzaiabc/article/details/81008330 无论遇到的网页代码是何种编码方式,都可以用以下方法统一解决 imp ...
- [转]oracle EBS 基础100问
from:http://www.cnblogs.com/xiaoL/p/3593691.html http://f.dataguru.cn/thread-51057-1-1.html 1001 OR ...
随机推荐
- Java知多少(105)套接字(Socket)
网络应用模式主要有: 主机/终端模式:集中计算,集中管理: 客户机/服务器(Client/Server,简称C/S)模式:分布计算,分布管理: 浏览器/服务器模式:利用Internet跨平台. www ...
- 用 .NET Reflector 8 查看 System.Windows.Controls 命名空间下的类
为了学习自定义控件,就想看看WPF基本元素的代码.使用到工具.NET Reflector. System.Windows.Controls 命名空间在PresentationFramework.dll ...
- DDD:两篇不错的文章
文章列表 Coding for Domain-Driven Design: Tips for Data-Focused Devs. Strengthening your domain: Aggrega ...
- 编译Libgdiplus遇到的问题
https://github.com/mono/libgdiplus/releases 下载最新版本 解压并执行 ./autogen.sh,在执行此步时遇到如下问题,并帖出解决办法 问题:执行 ...
- 《微信小程序七日谈》- 第二天:你可能要抛弃原来的响应式开发思维
<微信小程序七日谈>系列文章: 第一天:人生若只如初见: 第二天:你可能要抛弃原来的响应式开发思维: 第三天:玩转Page组件的生命周期: 第四天:页面路径最多五层?导航可以这么玩 上篇文 ...
- PerfMap – 显示前端网站性能的热力图插件
PerfMap 是用来分析前端性能,基于资源定时 API 生成网页资源加载的前端性能热图.热图的颜色和第一个毫秒值指示在什么时候页面的图像加载完毕,这是用户体验的一个很好的指标.括号中的第二个值是浏览 ...
- SecureCRT连接linux设置vim显示颜色
只需要两个步骤: 1) 选项 --> 会话选项 --> 终端 --> 仿真 --> 勾选“ANSI 颜色”. 2) 在.bashrc中添加:export TERM=xter ...
- 微软必应词典客户端的案例分析——个人Week3作业
第一部分 调研,评测 Bug探索 Bug No1.高亮语义匹配错位 环境: windows8,使用必应词典版本PC版:3.5.0 重现步骤: 1. 搜索"funny face"这一 ...
- [ASP.NET] 下一代ASP.NET开发规范:OWIN
今天投简历 准备面试了... 本节目录: OWIN简介 OWIN规范 Katana Hello World(3种Host) 自定义Middleware OWIN简介 OWIN(Open Web Int ...
- 准备.Net转前端开发-WPF界面框架那些事,值得珍藏的8个问题
题外话 不出意外,本片内容应该是最后一篇关于.Net技术的博客,做.Net的伙伴们忽喷忽喷..Net挺好的,微软最近在跨平台方面搞的水深火热,更新也比较频繁,而且博客园的很多大牛也写的有跨平台相关技术 ...