真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

利用fnd_flex_keyval包輕松獲取關(guān)鍵性彈性域組合描述字段

轉(zhuǎn)自: https://blog.csdn.net/rfb0204421/article/details/8204103

目前成都創(chuàng)新互聯(lián)已為近千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、網(wǎng)站運營、企業(yè)網(wǎng)站設(shè)計、金沙網(wǎng)站維護等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

在Oracle Forms客戶化開發(fā)中,如果遇到有在Form上提供關(guān)鍵性彈性域(以下簡稱“鍵彈性域”)功能支持的時候,我們可以利用FND_KEY_FLEX.DEFINE函數(shù)來輕松完成所有的初始化工作。其中也包括鍵彈性域的組合描述字段的顯示的初始化:只要在FND_KEY_FLEX.DEFINE調(diào)用時指定了DESCRIPTION參數(shù)即可。然而有時我們僅是想要顯示這個描述組合字段,僅此而已。并不需要提供完整的鍵彈性域功能。那么我們有什么快速而有效的方法來得到這個描述組合字段呢?試試下面的fnd_flex_keyval包里的方法吧~

實例:獲取庫存物料的物料類別集中的類別組合“描述”字段

需要用到的方法:

  • fnd_flex_keyval.validate_segs()
  • fnd_flex_keyval.concatenated_descriptions()
fnd_flex_keyval.validate_segs 的參數(shù)很多,對于獲取物料類別組合字段我們僅需要其中的五個參數(shù),如下:

fnd_flex_keyval.validate_segs(
operation        => < OPERATIONS>
, appl_short_name  => < Application Short Name>
, key_flex_code    => < Key Flex Code>
, structure_number => < ID_FLEX_NUM>
, concat_segments  => < CONCATENATED_SEGMENTS>
);

參數(shù)說明:
- operation 可選值有:
  • FIND_COMBINATION - 所給定的組合字段必須在系統(tǒng)中已經(jīng)被定義
  • CREATE_COMBINATION - 如果組合字段不存在,則在系統(tǒng)中創(chuàng)建該組合
  • CREATE_COMB_NO_AT - 功能和CREATE_COMBINATION相同,只是不像前者要使用相對獨立的子事務(wù)autonomous transaction
  • CHECK_COMBINATION - 只是檢查一下給定的組合字段是否合法,不管檢查結(jié)果如何,都不創(chuàng)建新的組合
  • DEFAULT_COMBINATION - 返回默認的最小組合(這個參數(shù)值我也沒太搞懂,呵呵)
  • CHECK_SEGMENTS - 分別驗證字段(這個也很糊涂~)
- appl_short_name 應(yīng)用程序簡稱,例如庫存模塊對應(yīng)的應(yīng)用簡稱為INV
- key_flex_code 鍵彈性域代碼,可以在鍵彈性域定義界面找到,例如MCAT, GL#等等
- structure_number  指定鍵彈性域下的某個結(jié)構(gòu)NUM,可以在鍵彈性域定義界面找到,對應(yīng)字段為ID_FLEX_NUM
- concat_segments  要獲取組合描述字段的對應(yīng)的“值“組合字段,例如: A.000.MISC
一旦初始化驗證字段成功,那么描述組合字段便可以通過調(diào)用fnd_flex_keyval.concatenated_descriptions()來得到了。
完整代碼如下:

FUNCTION get_concat_descriptions(p_concat_segs IN VARCHAR2) RETURN VARCHAR2
IS
BEGIN
IF fnd_flex_keyval.validate_segs(
operation        => 'FIND_COMBINATION' -- 請根據(jù)情況自行修改
, appl_short_name  => 'INV' -- 請根據(jù)情況自行修改
, key_flex_code    => 'MCAT' -- 請根據(jù)情況自行修改
, structure_number => 101 -- 請根據(jù)情況自行修改
, concat_segments  => p_concat_segs) THEN
RETURN (fnd_flex_keyval.concatenated_descriptions());
ELSE
RETURN '';
END IF;
END;

參數(shù)說明:
- operation 可選值有:
  • FIND_COMBINATION - 所給定的組合字段必須在系統(tǒng)中已經(jīng)被定義
  • CREATE_COMBINATION - 如果組合字段不存在,則在系統(tǒng)中創(chuàng)建該組合
  • CREATE_COMB_NO_AT - 功能和CREATE_COMBINATION相同,只是不像前者要使用相對獨立的子事務(wù)autonomous transaction
  • CHECK_COMBINATION - 只是檢查一下給定的組合字段是否合法,不管檢查結(jié)果如何,都不創(chuàng)建新的組合
  • DEFAULT_COMBINATION - 返回默認的最小組合(這個參數(shù)值我也沒太搞懂,呵呵)
  • CHECK_SEGMENTS - 分別驗證字段(這個也很糊涂~)
- appl_short_name 應(yīng)用程序簡稱,例如庫存模塊對應(yīng)的應(yīng)用簡稱為INV
- key_flex_code 鍵彈性域代碼,可以在鍵彈性域定義界面找到,例如MCAT, GL#等等
- structure_number  指定鍵彈性域下的某個結(jié)構(gòu)NUM,可以在鍵彈性域定義界面找到,對應(yīng)字段為ID_FLEX_NUM
- concat_segments  要獲取組合描述字段的對應(yīng)的“值“組合字段,例如: A.000.MISC
一旦初始化驗證字段成功,那么描述組合字段便可以通過調(diào)用fnd_flex_keyval.concatenated_descriptions()來得到了。
完整代碼如下:
 
FUNCTION get_concat_descriptions(p_concat_segs IN VARCHAR2) RETURN VARCHAR2
IS
BEGIN
IF fnd_flex_keyval.validate_segs(
operation        => 'FIND_COMBINATION' -- 請根據(jù)情況自行修改
, appl_short_name  => 'INV' -- 請根據(jù)情況自行修改
, key_flex_code    => 'MCAT' -- 請根據(jù)情況自行修改
, structure_number => 101 -- 請根據(jù)情況自行修改
, concat_segments  => p_concat_segs) THEN
RETURN (fnd_flex_keyval.concatenated_descriptions());
ELSE
RETURN '';
END IF;
END;

獲取貨位的描述:
--Get Stock Locators(MTLL) 庫存貨位的組合與描述
--SELECT cux_flex_pkg.get_mtll_flexfields(p_locator_id => 3950, p_organization_id => 7890, p_return => 'S') locator_name FROM dual;
FUNCTION get_mtll_flexfields(p_locator_id      NUMBER,
p_organization_id NUMBER,
p_return          VARCHAR2 DEFAULT 'S') RETURN VARCHAR2 IS
l_concatenated_descriptions VARCHAR2(2000);
l_success                   BOOLEAN;
l_concatenated_segments     VARCHAR2(2000);
c_structure_number          NUMBER;
c_key_flex_code             VARCHAR2(20);
c_appl_short_name           VARCHAR2(20);
l_application_id            NUMBER;
-- Keeps track of the current delimiter
l_delim         VARCHAR2(1) := '';
l_error_message VARCHAR2(1000);
BEGIN
--
--Bug: Value &VALUE for the flexfield segment Subinventory does not exist in the value set @VALUE_SET.
--如果在健彈性域定義的值集中使用了PROFILE,需要初始化賦值之后才行,否則會出現(xiàn)以上錯誤
--SELECT FND_PROFILE.VALUE_WNPS('MFG_ORGANIZATION_ID') FROM DUAL;
--fnd_global.apps_initialize(resp_appl_id => 401, resp_id => 65780, user_id => 1013436);
IF FND_PROFILE.VALUE_WNPS('MFG_ORGANIZATION_ID') IS NULL THEN
fnd_profile.put('MFG_ORGANIZATION_ID', p_organization_id);
END IF;
c_key_flex_code    := 'MTLL';
c_appl_short_name  := 'INV';
c_structure_number := 101;
SELECT application_id
INTO l_application_id
FROM fnd_application_vl a
WHERE a.application_short_name = c_appl_short_name;
-- Get the delimiter
l_delim := fnd_flex_apis.get_segment_delimiter(x_application_id => l_application_id, x_id_flex_code => c_key_flex_code, x_id_flex_num => c_structure_number);
--參數(shù)DATA_SET一定要設(shè)置,和物料的鍵彈性域定義的原理一樣:因為INVENTORY_LOCATION_ID在數(shù)據(jù)庫的基表中不是唯一的值
--SELECT set_defining_column_name,unique_id_column_name,application_table_name FROM fnd_id_flexs WHERE id_flex_code IN ('MTLL', 'MSTK');
l_success := fnd_flex_keyval.validate_ccid(appl_short_name  => c_appl_short_name,
key_flex_code    => c_key_flex_code,
structure_number => c_structure_number,
data_set         => to_char(p_organization_id), -- Requied
combination_id   => p_locator_id);
dbms_output.put_line('l_success = ' || to_char(sys.diutil.bool_to_int(l_success)));
l_error_message := fnd_flex_keyval.error_message;
IF l_success THEN
l_concatenated_descriptions := fnd_flex_keyval.concatenated_descriptions;
--dbms_output.put_line('Concatenated Descriptions : ' || l_concatenated_descriptions);
l_concatenated_segments := fnd_flex_keyval.concatenated_values;
--dbms_output.put_line('Concatenated Segments : ' || l_concatenated_segments);
ELSE
l_concatenated_segments     := NULL;
l_concatenated_descriptions := NULL;
fnd_message.set_name('FND', 'FLEX-SSV EXCEPTION');
fnd_message.set_token('MSG', l_error_message);
dbms_output.put_line(fnd_message.get);
RAISE app_exceptions.application_exception;
END IF;
IF p_return = 'S' THEN
RETURN(l_concatenated_segments);
ELSIF p_return = 'D' THEN
RETURN(l_concatenated_descriptions);
ELSE
RETURN(l_concatenated_segments);
END IF;
EXCEPTION
WHEN OTHERS THEN
RETURN NULL;
app_exception.raise_exception;
END get_mtll_flexfields;

庫存物料的組合與描述庫存物料的組合與描述:
FUNCTION get_mstk_flexfields(p_item_id      NUMBER,
p_organization_id NUMBER,
p_return          VARCHAR2 DEFAULT 'S') RETURN VARCHAR2 IS
l_concatenated_descriptions VARCHAR2(2000);
l_success                   BOOLEAN;
l_concatenated_segments     VARCHAR2(2000);
c_structure_number          NUMBER;
c_key_flex_code             VARCHAR2(20);
c_appl_short_name           VARCHAR2(20);
l_application_id            NUMBER;
-- Keeps track of the current delimiter
l_delim         VARCHAR2(1) := '';
l_error_message VARCHAR2(1000);
BEGIN
--
--如果在健彈性域定義的值集中使用了PROFILE,需要初始化賦值之后才行,否則會出現(xiàn)以上錯誤
--SELECT FND_PROFILE.VALUE_WNPS('MFG_ORGANIZATION_ID') FROM DUAL;
--fnd_global.apps_initialize(resp_appl_id => 401, resp_id => 65780, user_id => 1013436);
IF FND_PROFILE.VALUE_WNPS('MFG_ORGANIZATION_ID') IS NULL THEN
fnd_profile.put('MFG_ORGANIZATION_ID', p_organization_id);
END IF;
c_key_flex_code    := 'MSTK';
c_appl_short_name  := 'INV';
c_structure_number := 101;
SELECT application_id
INTO l_application_id
FROM fnd_application_vl a
WHERE a.application_short_name = c_appl_short_name;
-- Get the delimiter
l_delim := fnd_flex_apis.get_segment_delimiter(x_application_id => l_application_id, x_id_flex_code => c_key_flex_code, x_id_flex_num => c_structure_number);
--參數(shù)DATA_SET一定要設(shè)置,和物料的鍵彈性域定義的原理一樣:因為INVENTORY_LOCATION_ID在數(shù)據(jù)庫的基表中不是唯一的值
--SELECT set_defining_column_name,unique_id_column_name,application_table_name FROM fnd_id_flexs WHERE id_flex_code IN ('MTLL', 'MSTK');
l_success := fnd_flex_keyval.validate_ccid(appl_short_name  => c_appl_short_name,
key_flex_code    => c_key_flex_code,
structure_number => c_structure_number,
data_set         => to_char(p_organization_id), -- Requied
combination_id   => p_item_id);
dbms_output.put_line('l_success = ' || to_char(sys.diutil.bool_to_int(l_success)));
l_error_message := fnd_flex_keyval.error_message;
IF l_success THEN
l_concatenated_descriptions := fnd_flex_keyval.concatenated_descriptions;
--dbms_output.put_line('Concatenated Descriptions : ' || l_concatenated_descriptions);
l_concatenated_segments := fnd_flex_keyval.concatenated_values;
--dbms_output.put_line('Concatenated Segments : ' || l_concatenated_segments);
ELSE
l_concatenated_segments     := NULL;
l_concatenated_descriptions := NULL;
fnd_message.set_name('FND', 'FLEX-SSV EXCEPTION');
fnd_message.set_token('MSG', l_error_message);
dbms_output.put_line(fnd_message.get);
RAISE app_exceptions.application_exception;
END IF;
IF p_return = 'S' THEN
RETURN(l_concatenated_segments);
ELSIF p_return = 'D' THEN
RETURN(l_concatenated_descriptions);
ELSE
RETURN(l_concatenated_segments);
END IF;
EXCEPTION
WHEN OTHERS THEN
RETURN NULL;
app_exception.raise_exception;
END get_mstk_flexfields;

本文題目:利用fnd_flex_keyval包輕松獲取關(guān)鍵性彈性域組合描述字段
標(biāo)題鏈接:http://weahome.cn/article/jcgcsd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部