首页  ·  知识 ·  生产制造
OracleEBS客户化程序中格式化金额
网友    ERP  编辑:dezai   图片来源:网络
在Oracle EBS系统中,随处可见金额的显示格式,通常情况下都具有千分位符,同时有一定位数的精度,让我们先来看看一些现成的例子

让我们来看看这个金额的格式是如何来确定的:

 

1,正数显示的格式由预置文件:Currency:Positive Format来确定
2,负数显示的格式由预置文件:Currency:Negative Format来确定
3,是否显示千分位由预置文件:Currency:Thousands Separator的值来确定
4,而精度则是由币种的精度设置来决定的(在总帐模块进行设置)

 

从上面的描述可以知道要格式化金额显示的前提条件是:币种,如果没有明确的币种可以选择本位币

下面来看看在我们自己开发的程序中,如何实现上述的功能:
1,Form界面中控制金额的显示
只要在能够确定币种的时候使用Oralce提供的币种格式化函数 fnd_currency.get_format_mask 来进行Item格式掩码属性的设置即可
?[Copy to clipboard]View Code PLSQL
1
2
3
4
5
6
7
8
9
10
11
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 方法,可以使用如下的代码来格式化:
?[Copy to clipboard]View Code PLSQL
1
2
3
4
5
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专门提供了用户出口函数来解决这个问题,相对步骤更加复杂一些,就留作其它文章再描述吧。

本文作者:网友 来源:网络
CIO之家 www.ciozj.com 微信公众号:imciow
   
免责声明:本站转载此文章旨在分享信息,不代表对其内容的完全认同。文章来源已尽可能注明,若涉及版权问题,请及时与我们联系,我们将积极配合处理。同时,我们无法对文章内容的真实性、准确性及完整性进行完全保证,对于因文章内容而产生的任何后果,本账号不承担法律责任。转载仅出于传播目的,读者应自行对内容进行核实与判断。请谨慎参考文章信息,一切责任由读者自行承担。
延伸阅读