zoukankan      html  css  js  c++  java
  • Oracle EBS客户化程序中格式化金额

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

    dynamic_currency_example1 dynamic_currency_example2 dynamic_currency_example3

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

     

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

    dynamic_currency_profiles

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

    currency_precision

     

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

     

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

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

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

    ?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 方法,可以使用如下的代码来格式化:

    ?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专门提供了用户出口函数来解决这个问题,相对步骤更加复杂一些,就留作其它文章再描述吧。

    http://oracleseeker.com/2009/08/20/format_amount_mask_using_dynamic_currency_in_oracle_ebs/

  • 相关阅读:
    【作业】5个不合理的Xaml Control
    记录一下 mysql 的查询中like字段的用法
    BaseDao代码,用于连接数据库实行增删改查等操作
    Java的多态
    Java基础一
    数据库的设计
    JavaScript基础
    我注册博客的第一天
    JAVA异常处理流程理解
    javaweb中解决中文乱码问题
  • 原文地址:https://www.cnblogs.com/quanweiru/p/6515252.html
Copyright © 2011-2022 走看看