Oracle EBS客户化程序中格式化金额

在Oracle EBS系统中,随处可见金额的显示格式,通常情况下都具有千分位符,同时有一定位数的精度,让我们先来看看一些现成的例子

上面这些列子中的金额都显示了千分位符,同时具备以2位小数,难道这个格式就是程序写死的?答案显然是否定的。

 

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

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

 

从上面的描述可以知道要格式化金额显示的前提条件是:

 

下面来看看在我们自己开发的程序中,如何实现上述的功能:

1,Form界面中控制金额的显示

只要在能够确定币种的时候使用Oralce提供的币种格式化函数 来进行Item格式掩码属性的设置即可

1
2
3
4
5
6
7
8
9
10
11
app_item_propertyset_property 
   FORMAT_MASK
    fnd_currencyget_format_mask
      headerscurrency_code
      get_item_propertyMAX_LENGTH



 sobcurrency_code
  gl_sets_of_books sob
 sobset_of_books_id  fnd_profile

2,在数据库的PLSQL中格式化金额

如果编写的数据库PLSQL程序中需要格式化输出金额,Oracle提供了服务端的fnd_currency.get_format_mask 方法,可以使用如下的代码来格式化:

1
2
3
4
5
l_amount_char    
l_amount           
l_currency_code    
 
l_amount_char  amount fnd_currencyget_format_maskl_currency_code

3,在Report报表中格式化金额

对于在Report报表中格式化金额,Oracle专门提供了用户出口函数来解决这个问题,相对步骤更加复杂一些,就留作其它文章再描述吧。

详细请点击:http://www.verydemo.com/demo_c158_i85142.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值