首页 > DataFix > DATAFIX_AR反过帐的问题

DATAFIX_AR反过帐的问题

2008年12月16日 发表评论 阅读评论

/***********************************************************************************************************
概述:

问题: AR 会计分录传到总帐接口以后,用户在总帐中,没有导入这批日记帐之前,利用删除接口的程序把接口中的某一批数据给删除了。
       导致一批凭证丢失。
       
当时场景是这样的:
       1)客户的财务人员提交AR的过账程序,确实勾选了运行日记帐导入。
       但是由于某些原因导致:AR传总帐接口这一步是正常完成了。但是日记帐导入这一步没有正常完成。
       2)客户看到并发请求列表中有个红色的出错请求,就以为整个AR过账过程都错了,当然在总帐也没有查到相关日记帐。
       于是就再次运行AR过账程序,但是因为原来的数据已经被打上“已过账”标记,所以是过不去了。
       3)客户就以为是接口表中有错误数据所以导致不能再过账的(她的这个想法当然是错误的,但当时她确实就是这么以为的)
       于是她就删除接口的程序把接口中的某一批数据给删除了。
       4)这下可就完蛋了。接口中也没数据了,系统又不能再过账。到了这一步,客户就无能为力了。
       
***********************************************************************************************************/

怎么办? 

/***********************************************************************************************************
 1    根据用户 提交的  删除日记帐导入来源  的请求 来知道用户删除了哪一批数据
 ***********************************************************************************************************/

— 运行 总帐的 删除 接口程序 输入参数 request_id ,group_id 
— 如果不输入group_id  则,group_id 会被默认设置为-1 ,也就无法删除

— 并发请求 名称 = 删除日记帐导入来源   
— 并发请求ID = 550089
— 请求完成后查 接口表 

— 查德当时的运行参数:Receivables, 549291, 4427, 1

/*
GLLDEL module: 删除日记帐导入来源
+—————————————————————————+

当前的系统时间为 06-06-2007 13:58:17

+—————————————————————————+

>> glldel() 06-06-2007 13:58:17
SHRD0084: 从 GL_INTERFACE 中删除
SHRD0119: 从 GL_INTERFACE 中删除 147 记录。
SHRD0019: GLLDEL – 成功执行后退出处理。
*/

–查接口表
select * from gl.gl_interface where group_id = 4427
— 0 行 
–确实被删除
select * from gl.gl_interface
–1 POSTED -99 2005-4-30 Y 2005-4-30 10:28:31 -9999 A @#$% do not delete this record
–只有一条 OU屏蔽 而保留的记录
–发现数据确实被删除了。

–再查  AR_POSTING_CONTROL 表

  select * from AR_POSTING_CONTROL where   posting_control_id = 4427
–状态为Done  说明 AR传总帐接口是成功完成的

–查找被删除的记录

select * from  ar_adjustments_all  where   posting_control_id = 4427
— 0 行
select * from ar_misc_cash_distributions_all   where   posting_control_id = 4427
— 0 行
select * from  ar_receivable_applications_all  where   posting_control_id = 4427
— 61 行
— 备份到Excel 文件
select * from  ar_cash_receipt_history_all  where   posting_control_id = 4427
— 0 行
select * from RA_CUST_TRX_LINE_GL_DIST_ALL  where   posting_control_id = 4427
— 83行
— 备份到Excel文件
select * from  ar_transaction_history_all where   posting_control_id = 4427
–0行

–select * from  AR_PAYMENT_SCHEDULES_ALL where   posting_control_id = 4427
select * from  AR_CASH_BASIS_DISTS_ALL where   posting_control_id = 4427
— 0 行
–select * from AR_DISTRIBUTIONS_ALL where   posting_control_id = 4427
–select * from   AR_DISTRIBUTION_SETS_ALL where   posting_control_id = 4427

 –select * from AR_DISTRIBUTION_SET_LINES_ALL where   posting_control_id = 4427
 
–select * from  RA_INTERFACE_DISTRIBUTIONS_ALL  where   posting_control_id = 4427

/***********************************************************************************************************
2    使用  ARGCGP  来对这批数据进行 unpost 操作
 ***********************************************************************************************************/

— AR过帐标志重置程序 :ARGCGP
— Note:219307.1 对此程序的使用有明确的说明

–1 确保受影响的纪录的AR会计期是打开的

–2 确保受影响的记录未过到总帐
      –查总帐日记帐是否存在来自AR的Posting_control_id =8000的纪录
      select  jb.name,jh.*,jl.*
      from gl_je_lines jl, gl_je_headers jh, gl_je_batches jb
      where jl.je_header_id = jh.je_header_id
      and jh.je_batch_id = jb.je_batch_id
      and jb.name like ‘%4427%’
      
      select  jb.name
      from gl_je_lines jl, gl_je_headers jh, gl_je_batches jb
      where jl.je_header_id = jh.je_header_id
      and jh.je_batch_id = jb.je_batch_id
      and jb.name like ‘%4427%’      
      group by jb.name

— 发现没有来自 应收的 含 4427的批

     
      
–3 确保当前没有正在运行日记帐导入

–4 再次检查Posting_Control_id  的正确性,否则可能导致重复过帐。

— 按照  Note:219307.1  定义了并发程序 : ARGCGP_SD
–名称:SD AR Unposting

–提交了请求;
–参数 1, 4427, Y, N, N 4427
–请求运行出错

–检查发现 ar_receivable_applications_all 已经被重置。
–RA_CUST_TRX_LINE_GL_DIST_ALL 没有改变。

/*日志如下

=======================================
Parameters passed in:
     Set of Books Id:          1
     Posting Control Id:       4427
     Reset GL Posted Date:     Y
     Delete from GL_INTERFACE: N
     Debug Mode On:            Y
========================================

  当前的系统时间为 07-06-2007 16:23:37
*****************************************************
***** argurs *****
BEGIN TO RESET THE GL_POSTED_DATE
-> POSTING_CONTROL_ID = 4427

Resetting ar_adjustments…
Committed the reset – 0 lines

Resetting ar_misc_cash_distributions…
Committed the reset – 0 lines

Resetting ar_receivable_applications…
Committed the reset – 61 lines

Resetting ar_cash_receipt_history…
Committed the reset – 0 lines

Committed the reset – 0 lines

Resetting ra_cust_trx_line_gl_dist…

Oracle error in function ‘argurs’
 AR-ARGLTP: -20001 ORA-20001: 您无法删除已过帐记录。
ORA-06512: 在”APPS.RA_CU
AR-ARGCGP: Error from argurs
========================================
|   Cannot delete records from gl_interface.
|   Please delete records from gl_interface with group id of 4427
|   DO NOT submit any posting program until these records are deleted.
=======================================*/

— 到界面查看 ,发现 被重置的收款已经变成“未核销状态”

— 从备份的Excel文件中获取 第一条记录的  receivable_application_id ,检查这条记录
select * from ar_receivable_applications_all  where  receivable_application_id = 178374
— 把重置后的记录与重置前的记录相比较:发现 :重置的动作在于:
–就某一条AR中的会计分录而言:系统的这个重置程序  只是把POSTING_CONTROL_ID 改成 -3 并把GL_POSTED_DATE 设置为空

/***********************************************************************************************************
3    把重置成功的部分 再一次传总帐
 ***********************************************************************************************************/

— 用户再次运行 AR ->传总帐的程序
— 传输程序成功完成
— 日记帐导入失败
–日志的关键部分
— request_id =  551614

/*Error in: gllccl
Function return status: 0
Function Err Message: failure to get cross currency account
Function warning number: -1
*****************************************************
sqlcaid:   sqlabc: 0  sqlcode:  1403  sqlerrml: 27
sqlerrmc:
ORA-01403: 未找到数据

sqlerrp:   sqlerrd: 0 2 0 0 0 538976288
sqlwarn:           sqltext:  */

— 问 赵丰干
–答:总账/设置/账户/暂记  定义类别为“交叉币种”的账户   ; 这里没有设置暂记帐户
— 也就是说 要添加一条 来源=应收。类别=交叉币种 的帐户
— 相关讨论如下:

–=========================================
/*商云方 说:
老赵,汇兑损益 在AR 作不同币种的收款核销发票的时候 产不产生?也就是说在AR中是否要产生汇兑损益的会计分录?
赵丰干 说:
产生
赵丰干 说:
只要在AR中作跨币种收款核销,这个科目是必须的,无论是否有汇差产生
商云方 说:
哦,那么为什么在总帐导入日记帐的时候才报错呢? 在AR做核销的时候怎么不报错?
赵丰干 说:
因为GL中的凭证都是单币种的,因此跨币种核销业务会产生两张凭证,这个科目就是用来作中转的
赵丰干 说:
如果不设置的话,总账凭证就无法生成*/

恰好,老马也在县,就顺便跟老马也讨论了一下:
–=======================
/*商云方 说:
他们财务经理说不想做交叉币种核销,要求撤销核销。撤销港币发票。重新作人民币发票,然后再核销。
ma 说:
撤销核销不代表原来的交叉核销不存在了,只是系统产生出两笔正负相抵的交叉核销而已
商云方 说:
那怎么办呢?
ma 说:
那就追设一下,让凭证导入吗
商云方 说:
也就是说正负相抵消得交叉核销还是会传到总帐接口表吗?
ma 说:
会的
ma 说:
正负相抵不等于没有
商云方 说:
那要这么说,就只能在总帐中去设置那个暂挂帐户楼。
ma 说:
如果是一并导入的话,有可能可以导入的。
商云方 说:
准不准阿?
商云方 说:
老马,我们现在已经取消了人民币收款对港币发票的核销。
ma 说:
如正凭证:借:应收款未核销(RMB) 贷:应收款(HKD);这个凭证RMB和HKD的借贷都不平;再产生负凭证后:借:应收款(HKD) 贷:应收款未核销(RMB),那么导入的凭证会是:
商云方 说:
那么下一步,如何把那个港币发票作废掉?
商云方 说:
怎么操作?
ma 说:
借:应收款(HKD) 贷:应收款(HKD)
ma 说:
借:应收款未核销(RMB) 贷:应收款未核销(RMB)
ma 说:
你可以再传总帐,然后一起导
ma 说:
要求核销和取消核销的日期一定要一样
商云方 说:
那肯定不一样,
商云方 说:
核销是前几天进行的。取消核销时今天进行的。
ma 说:
或设上暂挂账户和选项,导入再取消此选项也可以
ma 说:
你在现场吗
商云方 说:
对,在

把问题给用户方反映了.

—  用户方 财务部经过讨论后 认为 目前还没想好要进行交叉币种核销的业务。
—  用户方决定 把 不同币种核销取消,然后对 外币发票 作贷项操作,然后再重做人民币发票,再核销。再传总帐

/***********************************************************************************************************
4    把刚才重置未成功的部分 再一次重置
 ***********************************************************************************************************/
 
—  由于刚才  ARGCGP_SD 只是重置了   ar_receivable_applications_all 表中的记录 ,而且经过再一次的调用AR->GL 的传输程序后
—  ar_receivable_applications_all 表中被重置的记录的  posting_control_id已经变成了另一个值.

— 现在需要想再次运行  ARGCGP_SD  来重置   RA_CUST_TRX_LINE_GL_DIST_ALL 中的记录
— 运行 SD AR Unposting 
–参数 1, 4427, Y, N, N 4427
–log 
/*===============================================================
***************************************************************
BEGIN TO RESET THE GL_POSTED_DATE
-> POSTING_CONTROL_ID = 4427

Resetting ar_adjustments…
Committed the reset – 0 lines

Resetting ar_misc_cash_distributions…
Committed the reset – 0 lines

Resetting ar_receivable_applications…
Committed the reset – 0 lines

Resetting ar_cash_receipt_history…
Committed the reset – 0 lines

Committed the reset – 0 lines

Resetting ra_cust_trx_line_gl_dist…

Oracle error in function ‘argurs’
 AR-ARGLTP: -20001 ORA-20001: 您无法删除已过帐记录。
ORA-06512: 在”APPS.RA_CU
AR-ARGCGP: Error from argurs
===============================================================
|   Cannot delete records from gl_interface.
|   Please delete records from gl_interface with group id of 4427
|   DO NOT submit any posting program until these records are deleted.
===============================================================
*/

— 系统标准程序重置未成功 ,手工重置

begin 

fnd_global.APPS_INITIALIZE(user_id =>1059 ,resp_id =>50330 ,resp_appl_id => 222);

update RA_CUST_TRX_LINE_GL_DIST_ALL
set GL_POSTED_DATE = NULL, POSTING_CONTROL_ID = -3
where posting_control_id = 4427;

end ;

— 上述过程执行失败,现象和并发程序执行失败是一样的
— 出错的时候会跳出 错误堆栈 ,根据错误堆栈,看源代码 知道有个Bug与此有关
— Metlink Note:272844.1 对此有说明

–措施:
— 暂时失效 触发器:ra_cust_trx_line_gl_dist_bri
— 重置请求运行完后再 启用

— 再次运行– 运行 SD AR Unposting 
–参数 1, 4427, Y, N, N 4427
— 成功完成
–log 
/*===============================================================
Parameters passed in:
     Set of Books Id:          1
     Posting Control Id:       4427
     Reset GL Posted Date:     Y
     Delete from GL_INTERFACE: N
     Debug Mode On:            Y
===============================================================

  当前的系统时间为 07-06-2007 18:50:05
***************************************************************
***** argurs *****
BEGIN TO RESET THE GL_POSTED_DATE
-> POSTING_CONTROL_ID = 4427

Resetting ar_adjustments…
Committed the reset – 0 lines

Resetting ar_misc_cash_distributions…
Committed the reset – 0 lines

Resetting ar_receivable_applications…
Committed the reset – 0 lines

Resetting ar_cash_receipt_history…
Committed the reset – 0 lines

Committed the reset – 0 lines

Resetting ra_cust_trx_line_gl_dist…
Committed the reset – 83 lines

Resetting ar_transaction_history…
Committed the reset – 0 lines
SUCCESSFUL.
****************************************************************/

— 到界面查发票的会计方法,已经变成 “未过帐” 状态。

/***********************************************************************************************************
5   用户操作
 ***********************************************************************************************************/

— 用户取消了收款与发票的核销

— 用户对此发票 作贷项操作

— 用户再做人民币发票

— 人民币收款 核销 人民币发票

— 在总帐设置暂挂帐户
–总账/设置/账户/暂记  定义类别为“交叉币种”的账户
— 来源=应收款管理系统
— 类别 = 交叉币种 
— 帐户 = 0003.00000.7201030101.00000000.000000.000000.000.000000.00

— 再次运行 AR->GL 的过帐程序
— 用户报告 一切OK  (暂记帐户是有内容的)

/***********************************************************************************************************
6   总结
 ***********************************************************************************************************/

解决方法:   利用系统提供的隐藏并发程序  ARGCGP 对这一批数据进行AR反过帐. 然后再重新过帐. 因为交叉币种核销问题,添加了暂记帐户。
注意点: ARGCGP 反过帐时, 由于ra_cust_trx_line_gl_dist_all 上有个数据库触发器会阻止ARGCGP 对表的修改,所以会导致失败.
       解决方法有两种
                       1是 临时实效此触发器. 待 ARGCGP运行完以后再恢复生效.
                      2 Oracle 说这是一个Bug, 可以打个patch 解决。打patch以后ARGCGP 就不会出现运行失败的情况了。
       我选择的是方法1,对于临时解决问题而言,比较简单。因为毕竟在很少的情况下用户需要进行反过帐操作。

 

 

关于作者:

昵称:商云方
档案信息:顾问, HAND张江技术中心
联系方式:你可以通过yunfang.shang@hand-china.com联系作者
点击查看发表过的所有文章...
本文永久链接: http://blog.retailsolution.cn/archives/2147

 

 

对本文的评价:

 

 

分类: DataFix 标签:
  1. 本文目前尚无任何评论.
  1. 本文目前尚无任何 trackbacks 和 pingbacks.
您必须在 登录 后才能发布评论.