在您过帐发票与付款的普通日记或定期日志包含可扣除增值税 (VAT),在葡萄牙语版本的 Microsoft Dynamics 导航 2009 年不可扣除增值税时您会收到下面的错误消息︰
"因为它将导致在 G/L 条目表中的不一致,不能完成交易记录。请检查在何处以及如何使用一致的函数在事务中查找导致错误的原因。请与您的系统管理员联系。表可以被标记为不一致期间全面任务,例如过帐。这样可以防止数据被不正确地更新。"
按照在代码更改部分,若要解决此问题的步骤。在下列产品中发生此问题︰
-
葡萄牙语版本的 Microsoft Dynamics 导航 2009 R2
-
葡萄牙语版本的 Microsoft Dynamics 导航 2009 SP1
它是由于特定的金额和增值税 D.%。
例如︰
1,15%的 0,25 = 0,002875,并对 2 个小数位的圆角为 0。
在 Codeunit 12 没有限制若要只发布金额 <> 0,以使增值税 (VAT) 条目将被跳过。
解决方案
修补程序信息
受支持的修补程序现已从 Microsoft 推出。然而,它仅用于纠正本文中描述的问题。它仅应用于正经历此特定问题的系统。此修补程序可能会接受进一步的测试。因此,如果这个问题没有对您造成严重的影响,我们建议您等待下一个 Microsoft Dynamics 导航 2009 服务包 或包含此修复程序的下一步的 Microsoft Dynamics 导航版本。
注意: 在特殊情况下,可免收的支持电话,可免收如果技术支持专业人员对 Microsoft Dynamics 和相关的产品的费用确定某个特定的更新能够解决您的问题。照常收取支持费用将应用于其他支持问题和对于特定更新无法解决的问题。
安装信息
Microsoft 提供的编程示例仅用于说明,没有任何明示或暗示的担保。这包括但不限于适销性或特定用途适用性的暗示担保。本文假定您熟悉所演示的编程语言和用于创建和调试过程的工具。Microsoft 的支持工程师可以帮助解释某个特定过程的功能。但是,他们不会修改这些示例以提供额外的功能或构建过程以满足您的特定要求。
注意:安装此修复程序之前,请验证所有 Microsoft Dynamics 导航客户端用户都注销系统。这包括 Microsoft Dynamics 导航应用程序服务器 (NAS) 服务。要实现此修补程序时,在登录的唯一客户端用户。
若要实现此修补程序,必须使用开发人员许可证。
我们建议在 Windows 登录窗口或数据库登录窗口中的用户帐户将分配该"超级"角色 id。如果不能将用户帐户分配成"超级"角色 ID,则必须验证用户帐户具有下列权限:
-
您将更改该对象的修改权限。
-
为系统对象 ID™ 5210对象和系统对象 ID 9015执行权限
对象。
注意:您不需要具有对数据存储区的权限,除非您需要执行数据修复。
代码更改
注始终测试代码修补程序在受控环境中之前将修补程序应用到生产计算机。在应用之前更改,请导入 SEPA 的所有更新。
若要解决此问题,请执行以下步骤:
-
更改代码中的InsertVAT函数中 Gen.Jnl。-开机自检线路 Codeunit (12),如下所示︰
现有代码 1...VATDifferenceLCY@1013 : Decimal;
SrcCurrVATDifference@1014 : Decimal;
BEGIN
WITH GenJnlLine DO BEGIN
...替换代码 1
...VATDifferenceLCY@1013 : Decimal;
SrcCurrVATDifference@1014 : Decimal;
// Add the following line.
VATAmountTotal@1015 : Decimal;
// End of the added line.
BEGIN
WITH GenJnlLine DO BEGIN
...现有代码 2
...GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);
InsertGLEntry(TRUE);
// Delete the following lines.
VATPostingSetup.TESTFIELD("Return VAT account (Sales)");
InitGLEntry(
VATPostingSetup."Return VAT account (Sales)",
// -GLEntryVATAmount - VATBase * VATPostingSetup."VAT N.D. %" / 100,
-TempVATAmount,
// -SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100,
ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),
TRUE,TRUE);
InsertGLEntry(TRUE);
// End of the deleted lines.
END
ELSE
...替换代码 2
...GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);
InsertGLEntry(TRUE);
END
ELSE
...现有代码 3
...END
ELSE
// Delete the following lines.
BEGIN
IF NOT GenJnlLine."UE Aquisition Not Accep." THEN BEGIN
VATPostingSetup.TESTFIELD("Purchase VAT Account");
InitGLEntry(
VATPostingSetup."Purchase VAT Account",
GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);
InsertGLEntry(TRUE);
END;
//--------
VATPostingSetup.TESTFIELD("Reverse Chrg. VAT Acc.");
InitGLEntry(
VATPostingSetup."Reverse Chrg. VAT Acc.",
// -GLEntryVATAmount - VATBase * VATPostingSetup."VAT N.D. %" / 100,
// ROUND(-GLEntryVATAmount - VATBase * VATPostingSetup."VAT N.D. %" / 100),
ROUND((- VATBase * VATPostingSetup."VAT D. %" / 100) - (VATBase * VATPostingSetup."VAT N.D. %" / 100)),
// -SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100,
ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),
TRUE,TRUE);
// End of the deleted lines.
InsertGLEntry(TRUE);
END;
...替换代码 3
...END
ELSE
// Add the following lines.
IF NOT GenJnlLine."UE Aquisition Not Accep." THEN BEGIN
VATPostingSetup.TESTFIELD("Purchase VAT Account");
InitGLEntry(
VATPostingSetup."Purchase VAT Account",
GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);
// End of the added lines.
InsertGLEntry(TRUE);
END;
...现有代码 4
...END;
END;
END;
END;
...替换代码 4
... END;
END;
// Add the following lines.
IF IsPurchaseReverseChargeVAT(UnrealizedVAT) THEN
IF "Document Type"= "Document Type"::"Credit Memo" THEN BEGIN
IF (NOT GenJnlLine."UE Aquisition Not Accep.") AND (TempVATAmount <> 0) THEN BEGIN
VATPostingSetup.TESTFIELD("Return VAT account (Sales)");
InitGLEntry(
VATPostingSetup."Return VAT account (Sales)",
-TempVATAmount,
ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),
TRUE,TRUE);
InsertGLEntry(TRUE);
END;
END ELSE BEGIN
VATAmountTotal
:= ROUND((- VATBase * VATPostingSetup."VAT D. %" / 100) - (VATBase * VATPostingSetup."VAT N.D. %" / 100));
IF VATAmountTotal <> 0 THEN BEGIN
VATPostingSetup.TESTFIELD("Reverse Chrg. VAT Acc.");
InitGLEntry(
VATPostingSetup."Reverse Chrg. VAT Acc.",VATAmountTotal,
ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),
TRUE,TRUE);
InsertGLEntry(TRUE);
END;
END;
// End of the added lines.
END;
END;
... -
更改代码中的IsPurchaseReverseChargeVAT函数中 Gen.Jnl。-开机自检线路 Codeunit (12),如下所示︰
现有代码...END;
BEGIN
END.
...替换代码
...END;
// Add the following lines.
LOCAL PROCEDURE IsPurchaseReverseChargeVAT@1110015(UnrealizedVAT@1110000 : Boolean) : Boolean;
BEGIN
EXIT(
(GenJnlLine."Gen. Posting Type" = GenJnlLine."Gen. Posting Type"::Purchase) AND (NOT UnrealizedVAT) AND
(VATPostingSetup."VAT Calculation Type" = VATPostingSetup."VAT Calculation Type"::"Reverse Charge VAT" ));
END;
// End of the added lines.
BEGIN
END.
...
系统必备组件
您必须具有要应用此修补程序的安装以下产品之一︰
-
葡萄牙语版本的 Microsoft Dynamics 导航 2009 R2
-
葡萄牙语版本的 Microsoft Dynamics 导航 2009 SP1
删除信息
您不能删除此修补程序。
状态
Microsoft 已经确认这是“适用于”一节中列出的 Microsoft 产品中的问题。
注意:这是直接从创建 Microsoft 支持部门内的"快速发布"的文章。此处包含的信息是作为为了响应新出现的问题而提供的。由于以使其可用的速度,而材料可能包含印刷错误,恕不另行通知,随时可能进行修订。其他考虑因素,请参阅使用条款。