Oracle EBS客户化程序中格式化金额
2010-09-16 16:16
429 查看
在Oracle EBS系统中,随处可见金额的显示格式,通常情况下都具有千分位符,同时有一定位数的精度,让我们先来看看一些现成的例子
上面这些列子中的金额都显示了千分位符,同时具备以2位小数,难道这个格式就是程序写死的?答案显然是否定的。
让我们来看看这个金额的格式是如何来确定的:
1,正数显示的格式由预置文件:Currency:Positive Format来确定
2,负数显示的格式由预置文件:Currency:Negative Format来确定
3,是否显示千分位由预置文件:Currency:Thousands Separator的值来确定
4,而精度则是由币种的精度设置来决定的(在总帐模块进行设置)
从上面的描述可以知道要格式化金额显示的前提条件是:币种,如果没有明确的币种可以选择本位币
下面来看看在我们自己开发的程序中,如何实现上述的功能:
1,Form界面中控制金额的显示
只要在能够确定币种的时候使用Oralce提供的币种格式化函数 fnd_currency.get_format_mask 来进行Item格式掩码属性的设置即可
代码为:
2,在数据库的PLSQL中格式化金额
如果编写的数据库PLSQL程序中需要格式化输出金额,Oracle提供了服务端的fnd_currency.get_format_mask 方法,可以使用如下的代码来格式化:
代码为:
3,在Report报表中格式化金额
对于在Report报表中格式化金额,Oracle专门提供了用户出口函数来解决这个问题 http://oracleseeker.com/2009/08/20/format_amount_mask_using_dynamic_currency_in_oracle_ebs/
上面这些列子中的金额都显示了千分位符,同时具备以2位小数,难道这个格式就是程序写死的?答案显然是否定的。
让我们来看看这个金额的格式是如何来确定的:
1,正数显示的格式由预置文件:Currency:Positive Format来确定
2,负数显示的格式由预置文件:Currency:Negative Format来确定
3,是否显示千分位由预置文件:Currency:Thousands Separator的值来确定
4,而精度则是由币种的精度设置来决定的(在总帐模块进行设置)
从上面的描述可以知道要格式化金额显示的前提条件是:币种,如果没有明确的币种可以选择本位币
下面来看看在我们自己开发的程序中,如何实现上述的功能:
1,Form界面中控制金额的显示
只要在能够确定币种的时候使用Oralce提供的币种格式化函数 fnd_currency.get_format_mask 来进行Item格式掩码属性的设置即可
代码为:
app_item_property.set_property('headers.amount_total', FORMAT_MASK,fnd_currency.get_format_mask(:headers.currency_code,get_item_property('headers.amount_total',MAX_LENGTH))) -- headers.amount_total 需要格式化金额对应的Item -- :headers.currency_code 币种对应的字段 -- 如果数据中没有币种可以通过下面代码取得本位币 SELECT sob.currency_code FROM gl_sets_of_books sob WHERE sob.set_of_books_id = fnd_profile.value('GL_SET_OF_BKS_ID');
2,在数据库的PLSQL中格式化金额
如果编写的数据库PLSQL程序中需要格式化输出金额,Oracle提供了服务端的fnd_currency.get_format_mask 方法,可以使用如下的代码来格式化:
代码为:
l_amount_char varchar2(100); l_amount number := 100000; l_currency_code varchar2(30) := 'USD'; l_amount_char := to_char(amount, fnd_currency.get_format_mask(l_currency_code,30))
3,在Report报表中格式化金额
对于在Report报表中格式化金额,Oracle专门提供了用户出口函数来解决这个问题 http://oracleseeker.com/2009/08/20/format_amount_mask_using_dynamic_currency_in_oracle_ebs/
相关文章推荐
- Oracle EBS客户化程序中格式化金额
- Oracle EBS客户化程序中格式化金额
- Oracle EBS客户化程序中格式化金额
- oracle 金额格式化
- Oracle EBS 问题集锦 - 程序 xla_accounting_pkg.ValidateAAD中出现内部错误
- 自己编写了Oracle EBS程序自动移植脚本
- Oracle EBS新建Java 并发程序(Java Concurrent Program)
- Oracle EBS 基于Host(主机文件)并发程序的开发
- 诊断 oracle ERP/EBS 低效的程序
- ORACLE EBS程序重置密码
- oracle 金额格式化
- Oracle EBS 12 目录结构
- oracle 函数to_char(数据,'FM999,999,999,999,990.00') 格式化数据
- windows server 2003 64位下32位程序无法通过oracle64客户端连接数据库
- 使用WebService与Oracle EBS进行集成
- Oracle EBS FND User Info API
- Oracle.DataAccess.Client.OracleException: 提供程序与此版本的 Oracle 客户机不兼容
- 写一段Jdbc连Oracle的程序,并实现数据查询
- Jmail 发送程序,格式化日期时间,FSO文件操作
- 写一个程序,语言不限,能将人民币金额从阿拉伯数字转换为大写汉字表示。例如,把1234.56转换为壹仟贰佰叁拾肆圆零伍角陆分。