Applies To
Dynamics NAV 2009

狀況

KB3001759KB3036811 ,在 [Microsoft 動態航行點 2009年中實作修正後,[G/L 項目可以是未套用。不過,有錯誤的 G/L 項目-增值稅項目都會連結張貼在應用程式。請依照下列程式碼變更一節,若要解決這個問題的步驟。下列產品中,就會發生這個問題︰

  • Microsoft 動態航行點 2009 R2

  • Microsoft 動態航行點 2009 SP1

解決方案

Hotfix 資訊

已經可以從 Microsoft 取得支援的 hotfix。不過,它只被用來修正本文所述的問題。它只適用於發生此特定問題的系統上。此 hotfix 可能會接受其他測試。因此,如果此問題不會嚴重影響,我們建議您等候下一步的 Microsoft 動態航行點 2009 service pack 或包含此 hotfix 的下一個 Microsoft 動態航行點版本。注意 在特殊的情況下,通常會支援呼叫可能已被取消如果技術支援專業人員的 Microsoft 動態及相關的產品所產生的費用會決定某特定更新程式可以解決您的問題。收取支援費用會套用,如果有其他支援問題是,不能限定的特定更新程式。

安裝資訊

Microsoft 會提供程式設計範例僅供說明,而不做任何明示或默示的保證。這包括,但不限於適售性或適合某特定用途之默示擔保責任。本文假設您已相當熟悉使用的我們所示範的程式設計語言以及建立和偵錯程序所使用的工具。Microsoft 技術支援工程師可以協助解釋特定程序的功能。不過,它們不會修改這些範例以提供附加功能或建構程序來滿足您特定需求。注意套用此 hotfix 之前,請確認所有的 Microsoft 動態航行點用戶端使用者會登出系統。這包括 Microsoft 動態航行點應用程式伺服器 (NAS) 服務。您應該是唯一的用戶端使用者已登入,當您實作此 hotfix。若要實作此 hotfix,您必須有開發人員授權。我們建議您在 Windows 登入] 視窗中的色彩,或資料庫登入] 視窗中的使用者帳戶被指派 「 進階 」 的角色識別碼。如果使用者帳戶不能指派為 「 超級 」 的角色識別碼,您必須確認使用者帳戶具有下列權限︰

  • 您將會變更物件的 [修改] 權限。

  • 執行權限的系統物件 ID 5210物件和系統物件 ID 9015物件。

注意您沒有擁有資料存放區的權限,除非您需要執行資料修復。

程式碼變更

注意永遠測試程式碼修正在受控制的環境中才能套用到實際執行電腦的修正程式。若要解決這個問題,請依照下列步驟執行:

  1. 變更程式碼在UnapplyCustLedgEntry函式在 Gen.Jnl。-張貼行 codeunit (12),如下所示︰現有的程式碼 1

    ...    NegativeLCYAppAmt@1021 : Decimal;      PositiveACYAppAmt@1020 : Decimal;      NegativeACYAppAmt@1019 : Decimal;// Delete the following lines.VatBaseSum@1008 : ARRAY [2] OF Decimal;EntryNoBegin@1025 : ARRAY [2] OF Integer;// End of the deleted lines.      i@1027 : Integer;      TempVatEntryNo@1028 : Integer;    BEGIN...

    取代程式碼 1

    ...  NegativeLCYAppAmt@1021 : Decimal;      PositiveACYAppAmt@1020 : Decimal;      NegativeACYAppAmt@1019 : Decimal;// Add the following lines.VatBaseSum@1008 : ARRAY [3] OF Decimal;EntryNoBegin@1025 : ARRAY [3] OF Integer;// End of the added lines.      i@1027 : Integer;      TempVatEntryNo@1028 : Integer;    BEGIN...

    現有的程式碼 2

    ... VATEntry2."Entry No." := NextVATEntryNo;              NextVATEntryNo := NextVATEntryNo + 1;              VATEntry2.INSERT;              TempVatEntry.DELETE;            END;            IF (VATPostingSetup."Adjust for Payment Discount") AND...

    取代程式碼 2

    ...VATEntry2."Entry No." := NextVATEntryNo;              NextVATEntryNo := NextVATEntryNo + 1;              VATEntry2.INSERT;// Add the following lines.IF VATEntry2."Unrealized VAT Entry No." = 0 THEN BEGINGLEntryTmp."Entry No." := NextEntryNo;GLEntryVatEntrylink.InsertLink(GLEntryTmp,VATEntry2);END;// End of the added lines.              TempVatEntry.DELETE;            END;            IF (VATPostingSetup."Adjust for Payment Discount") AND...

    現有的程式碼 3

    ... IF TempVatEntry.FINDSET THEN BEGIN            REPEAT              CASE TRUE OF                VatBaseSum[2] + TempVatEntry.Base = DtldCustLedgEntry2."Amount (LCY)":                  i := 3;                VatBaseSum[1] + TempVatEntry.Base = DtldCustLedgEntry2."Amount (LCY)":...

    取代程式碼 3

    ...IF TempVatEntry.FINDSET THEN BEGIN            REPEAT              CASE TRUE OF// Add the followoing lines.VATBaseSum[3] + TempVatEntry.Base = DtldCustLedgEntry2."Amount (LCY)":i := 4;// End of the added lines.                VatBaseSum[2] + TempVatEntry.Base = DtldCustLedgEntry2."Amount (LCY)":                  i := 3;                VatBaseSum[1] + TempVatEntry.Base = DtldCustLedgEntry2."Amount (LCY)":...

    現有的程式碼 4

    ...END;                  TempVatEntry := VATEntrySaved;                UNTIL TempVatEntry.NEXT = 0;// Delete the following line.FOR i := 1 TO 2 DO BEGIN// End of the deleted line.                  VatBaseSum[i] := 0;                  EntryNoBegin[i] := 0;                END;...

    取代程式碼 4

    ...END;                  TempVatEntry := VATEntrySaved;                UNTIL TempVatEntry.NEXT = 0;// Add the following line.FOR i := 1 TO 3 DO BEGIN// End of the added line.                  VatBaseSum[i] := 0;                  EntryNoBegin[i] := 0;                END;...

    現有的程式碼 5

    ...END;                TempVatEntry.SETRANGE("Entry No.",0,999999);              END ELSE BEGIN                VatBaseSum[2] := VatBaseSum[1] + TempVatEntry.Base;                VatBaseSum[1] := TempVatEntry.Base;                EntryNoBegin[2] := EntryNoBegin[1];                EntryNoBegin[1] := TempVatEntry."Entry No.";              END;...

    取代程式碼 5

    ...END;                TempVatEntry.SETRANGE("Entry No.",0,999999);              END ELSE BEGIN// Add the following line.VatBaseSum[3] += TempVATEntry.Base;// End of the added line.                VatBaseSum[2] := VatBaseSum[1] + TempVatEntry.Base;                VatBaseSum[1] := TempVatEntry.Base;// Add the folloiwng lines.           IF EntryNoBegin[3] > 0 THENEntryNoBegin[3] := TempVatEntry."Entry No.";// End of the added lines.EntryNoBegin[2] := EntryNoBegin[1];                EntryNoBegin[1] := TempVatEntry."Entry No.";              END;...
  2. 變更程式碼在UnapplyVendLedgEntry函式在 Gen.Jnl。-張貼行 codeunit (12),如下所示︰現有的程式碼 1

    ...    NegativeLCYAppAmt@1021 : Decimal;      PositiveACYAppAmt@1020 : Decimal;      NegativeACYAppAmt@1019 : Decimal;// Delete the following lines.VatBaseSum@1029 : ARRAY [2] OF Decimal;EntryNoBegin@1028 : ARRAY [2] OF Integer;// End of the deleted lines.      i@1027 : Integer;      TempVatEntryNo@1025 : Integer;    BEGIN...

    取代程式碼 1

    ...    NegativeLCYAppAmt@1021 : Decimal;      PositiveACYAppAmt@1020 : Decimal;      NegativeACYAppAmt@1019 : Decimal;      V// Add the following lines.atBaseSum@1029 : ARRAY [3] OF Decimal;EntryNoBegin@1028 : ARRAY [3] OF Integer;// End of the added lines.      i@1027 : Integer;      TempVatEntryNo@1025 : Integer;    BEGIN...

    現有的程式碼 2

    ...VatEntry2."Entry No." := NextVATEntryNo;              NextVATEntryNo := NextVATEntryNo + 1;              VatEntry2.INSERT;              TempVatEntry.DELETE;            END;            IF (VATPostingSetup."Adjust for Payment Discount") AND...

    取代程式碼 2

    ...VatEntry2."Entry No." := NextVATEntryNo;              NextVATEntryNo := NextVATEntryNo + 1;              VatEntry2.INSERT;// Add the following lines.IF VatEntry2."Unrealized VAT Entry No." = 0 THEN BEGINGLEntryTmp."Entry No." := NextEntryNo;GLEntryVatEntrylink.InsertLink(GLEntryTmp,VatEntry2);END;// End of the added lines.              TempVatEntry.DELETE;            END;            IF (VATPostingSetup."Adjust for Payment Discount") AND...

    現有的程式碼 3

    ...  IF TempVatEntry.FINDSET THEN BEGIN            REPEAT              CASE TRUE OF                VatBaseSum[2] + TempVatEntry.Base = DtldVendLedgEntry2."Amount (LCY)":                  i := 3;                VatBaseSum[1] + TempVatEntry.Base = DtldVendLedgEntry2."Amount (LCY)":...

    取代程式碼 3

    ...IF TempVatEntry.FINDSET THEN BEGIN            REPEAT              CASE TRUE OF// Add the following lines.VATBaseSum[3] + TempVatEntry.Base = DtldVendLedgEntry2."Amount (LCY)":i := 4;// End of the added lines.                VatBaseSum[2] + TempVatEntry.Base = DtldVendLedgEntry2."Amount (LCY)":                  i := 3;                VatBaseSum[1] + TempVatEntry.Base = DtldVendLedgEntry2."Amount (LCY)":...

    現有的程式碼 4

    ...END;                TempVatEntry.SETRANGE("Entry No.",0,999999);              END ELSE BEGIN                VatBaseSum[2] := VatBaseSum[1] + TempVatEntry.Base;                VatBaseSum[1] := TempVatEntry.Base;                EntryNoBegin[2] := EntryNoBegin[1];                EntryNoBegin[1] := TempVatEntry."Entry No.";              END;...

    取代程式碼 4

    ... END;                TempVatEntry.SETRANGE("Entry No.",0,999999);              END ELSE BEGIN// Add the following line.VatBaseSum[3] += TempVATEntry.Base;// End of the added line.                VatBaseSum[2] := VatBaseSum[1] + TempVatEntry.Base;                VatBaseSum[1] := TempVatEntry.Base;// Add the following lines.IF EntryNoBegin[3] > 0 THENEntryNoBegin[3] := TempVatEntry."Entry No.";// End of the added lines.                EntryNoBegin[2] := EntryNoBegin[1];                EntryNoBegin[1] := TempVatEntry."Entry No.";              END;...
  3. 變更程式碼在InsertVatEntriesFromTemp函式在 Gen.Jnl。-張貼行 codeunit (12),如下所示︰現有的程式碼

    ... DtldCVLedgEntryBuf."Entry Type"::"Payment Tolerance (VAT Excl.)":          TempVatEntry.SETRANGE("Entry No.",2000000,2999999)      END;// Delete the following line.TempVatEntry.FINDSET;// End of the deleted line.      REPEAT        VATEntry := TempVatEntry;        VATEntry."Entry No." := NextVATEntryNo;        VATEntry.INSERT;        NextVATEntryNo := NextVATEntryNo + 1;        IF VATEntry."Unrealized VAT Entry No." = 0 THEN          GLEntryVatEntrylink.InsertLink(GLEntry,VATEntry);        TempVatEntry.DELETE;        LinkedAmount := LinkedAmount + VATEntry.Base;        Complete := LinkedAmount = -DtldCVLedgEntryBuf."Amount (LCY)";      UNTIL Complete OR (TempVatEntry.NEXT = 0);    END;    LOCAL PROCEDURE CaptureOrRefundCreditCardPmnt@85() : Integer;...

    取代程式碼

    ...DtldCVLedgEntryBuf."Entry Type"::"Payment Tolerance (VAT Excl.)":          TempVatEntry.SETRANGE("Entry No.",2000000,2999999)      END;// Add the following line.IF TempVatEntry.FINDSET THEN// End of the added line.        REPEAT          VATEntry := TempVatEntry;          VATEntry."Entry No." := NextVATEntryNo;          VATEntry.INSERT;          NextVATEntryNo := NextVATEntryNo + 1;          IF VATEntry."Unrealized VAT Entry No." = 0 THEN            GLEntryVatEntrylink.InsertLink(GLEntry,VATEntry);          TempVatEntry.DELETE;          LinkedAmount := LinkedAmount + VATEntry.Base;          Complete := LinkedAmount = -DtldCVLedgEntryBuf."Amount (LCY)";        UNTIL Complete OR (TempVatEntry.NEXT = 0);    END;    LOCAL PROCEDURE CaptureOrRefundCreditCardPmnt@85() : Integer;...

先決條件

您必須具備套用此 hotfix 之後安裝下列產品的其中一個︰

  • Microsoft 動態航行點 2009 R2

  • Microsoft 動態航行點 2009 SP1

此外,您必須擁有KB3001759KB3036811安裝。

移除資訊

您無法移除此 hotfix。

狀態

Microsoft 已確認這是<套用>一節所列出的 Microsoft 產品的問題。

注意這是直接從 Microsoft 支援組織內建立的「快速發行」文件。本文件所包含的現狀資訊是針對新興問題的回應。為縮短使其可用的時程,資料可能會包含印刷錯誤,且可能會隨時進行修改而不另行通知。如其他考量,請參閱 「使用規定」。

Need more help?

Want more options?

探索訂閱權益、瀏覽訓練課程、瞭解如何保護您的裝置等等。