Oracle EBS在编码方式为AL32UTF8时的注意事项

2024-01-15 11:58

本文主要是介绍Oracle EBS在编码方式为AL32UTF8时的注意事项,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

现如今的EBS系统中,为了推进国际化的进程,以及系统向全球化的扩展,在Oracle数据库的编码方式上渐渐从支持中国本土简体中文的ZHS16GBK转向了更趋于国际化的AL32UTF8编码方式。但随之而来在中国就会产生很多问题,例如:

  • 其他的外围系统仍然使用简体中文GB2312/ZHS16GBK编码,在接口文件传输时由于编码不一致而产生乱码问题
  • Excel不兼容,简体中文版的Excel在读取文本文件时采用的是默认的简体中文编码方式打开,所以已UTF-8编码的文件(如CSV文件)在打开时会产生乱码问题

所以在中国的IT系统,一旦选择采用了AL32UTF8的国际化编码方式之后,了解一些编码方式的区别以及常见问题的解决方法是非常必要的。

 

编码方式

这里就不深入讨论编码的知识了,简单阐述一下二者的不同之处,见如下表格:

编码方式隶属于一个中文字符所占字节说明
ZHS16GBKANSI2与所有隶属于ANSI的编码兼容
AL32UTF8Unicode3与所有隶属于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 ENCODINGSITEUTF8
ICX: Client IANA EncodingSITEUnicode (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函数或文本编辑器)

Detect language » Hungarian

这篇关于Oracle EBS在编码方式为AL32UTF8时的注意事项的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/608813

相关文章

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.

查看Oracle数据库中UNDO表空间的使用情况(最新推荐)

《查看Oracle数据库中UNDO表空间的使用情况(最新推荐)》Oracle数据库中查看UNDO表空间使用情况的4种方法:DBA_TABLESPACES和DBA_DATA_FILES提供基本信息,V$... 目录1. 通过 DBjavascriptA_TABLESPACES 和 DBA_DATA_FILES

Python中__new__()方法适应及注意事项详解

《Python中__new__()方法适应及注意事项详解》:本文主要介绍Python中__new__()方法适应及注意事项的相关资料,new()方法是Python中的一个特殊构造方法,用于在创建对... 目录前言基本用法返回值单例模式自定义对象创建注意事项总结前言new() 方法在 python 中是一个

Springboot的自动配置是什么及注意事项

《Springboot的自动配置是什么及注意事项》SpringBoot的自动配置(Auto-configuration)是指框架根据项目的依赖和应用程序的环境自动配置Spring应用上下文中的Bean... 目录核心概念:自动配置的关键特点:自动配置工作原理:示例:需要注意的点1.默认配置可能不适合所有场景

Oracle登录时忘记用户名或密码该如何解决

《Oracle登录时忘记用户名或密码该如何解决》:本文主要介绍如何在Oracle12c中忘记用户名和密码时找回或重置用户账户信息,文中通过代码介绍的非常详细,对同样遇到这个问题的同学具有一定的参... 目录一、忘记账户:二、忘记密码:三、详细情况情况 1:1.1. 登录到数据库1.2. 查看当前用户信息1.

Spring Cloud Hystrix原理与注意事项小结

《SpringCloudHystrix原理与注意事项小结》本文介绍了Hystrix的基本概念、工作原理以及其在实际开发中的应用方式,通过对Hystrix的深入学习,开发者可以在分布式系统中实现精细... 目录一、Spring Cloud Hystrix概述和设计目标(一)Spring Cloud Hystr

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

PLsql Oracle 下载安装图文过程详解

《PLsqlOracle下载安装图文过程详解》PL/SQLDeveloper是一款用于开发Oracle数据库的集成开发环境,可以通过官网下载安装配置,并通过配置tnsnames.ora文件及环境变... 目录一、PL/SQL Developer 简介二、PL/SQL Developer 安装及配置详解1.下