Oracle EBS在编码方式为AL32UTF8时的注意事项
2016-03-11 20:12
281 查看
现如今的EBS系统中,为了推进国际化的进程,以及系统向全球化的扩展,在Oracle数据库的编码方式上渐渐从支持中国本土简体中文的ZHS16GBK转向了更趋于国际化的AL32UTF8编码方式。但随之而来在中国就会产生很多问题,例如:其他的外围系统仍然使用简体中文GB2312/ZHS16GBK编码,在接口文件传输时由于编码不一致而产生乱码问题
Excel不兼容,简体中文版的Excel在读取文本文件时采用的是默认的简体中文编码方式打开,所以已UTF-8编码的文件(如CSV文件)在打开时会产生乱码问题
所以在中国的IT系统,一旦选择采用了AL32UTF8的国际化编码方式之后,了解一些编码方式的区别以及常见问题的解决方法是非常必要的。EBS基础设置请确保一下表格中列示的配置文件已经设置了正确的值:
当为文本类型输出格式设置新的打开方式时,请确保“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/shcp $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打开会出现乱码的情况:总结1. 检查配置文件和View Options是否设置正确2. HTML格式报表记得要动态从系统中获取encoding3. PDF报表记得安装字体4. 输出到外部的文件需要进行必要转码操作(convert函数或文本编辑器)
Excel不兼容,简体中文版的Excel在读取文本文件时采用的是默认的简体中文编码方式打开,所以已UTF-8编码的文件(如CSV文件)在打开时会产生乱码问题
所以在中国的IT系统,一旦选择采用了AL32UTF8的国际化编码方式之后,了解一些编码方式的区别以及常见问题的解决方法是非常必要的。EBS基础设置请确保一下表格中列示的配置文件已经设置了正确的值:
配置文件名称 | 设置层 | 配置文件值 |
FND: NATIVE CLIENT ENCODING | SITE | UTF8 |
ICX: Client IANA Encoding | SITE | Unicode (UTF-8) |
相关文章推荐
- 将oracle数据库的编码变成utf-8
- Oracle存储过程编译卡死的解决方法
- 在maven中安装oracle11g驱动
- 关于Oracle 11gR2中的Database Smart Flash Cache特性以及该特性所适用的操作系统
- VC6.0下更改字体(win64) oracle解锁用户
- Oracle与MySQL的几点区别
- centos7上安装oracle 12c
- Oracle的Merge into语法
- Oracle insert语句执行之后返回插入数据的sys_guid()
- Oracle数据库远程连接设置
- PL/SQL连接Oracle10g的问题总结
- ORACLE根据汉字返回拼音的包--强大
- Oracle_create an index using unusable
- 静默安装oracle后,启动oem报错,解决方法!
- Oracle中修改sysman和dbsnmp密码正确流程
- 如何在windows中安装Oracle的SQLPlus
- Oracle函数to_char应用示例
- Oracle11g创建表空间语句
- oracle创建database links语句
- SQLserver Delete from where 与Oracle delete from where 的差异