Eine große Rechnung Rundungsbetrag wird beim Buchen einer Rechnung für einen Debitor, eine MwSt.-Buchungsgruppe verwendet in der Feld "Advanced Rechnungstyp Korrektur" auf Ungarisch Version von Microsoft Dynamics NAV 2009 R2 festgelegt ist, falsch

Vorlage: CPR - Navision Fix-Vorlage

FEHLER #: 175827 (Content Maintenance)

Dieser Artikel bezieht sich auf Microsoft Dynamics NAV für das Gebietsschema Ungarisch (Hu).

Problembeschreibung

Das folgende Szenario in Ungarisch Version von Microsoft Dynamics NAV 2009 R2:

  • Sie wenden das Update Vorauszahlung für Ungarisch Version von Microsoft Dynamics NAV 2009 R2.

  • Feld Vorauszahlung wird zu in der Finanzbuchhaltung Einrichtung Form festgelegt.

  • Legen Sie Erweiterte Rechnung Korrektur Feld Absolute für eine Buchungsgruppe Mehrwertsteuer (MwSt.).

  • Sie erstellen einen Auftrag für einen Debitor, der die MwSt.-Gruppe verwendet.

  • Sie Buchen eine Vorauszahlung und Fortschritt Rechnung für den Debitor.

  • Sie liefern und fakturieren den Auftrag.

In diesem Szenario wird unerwartet Groß Rechnungsrundungsbeträge Eintrag erstellt.


Problemlösung

Hotfix-Informationen

Ein unterstützter Hotfix ist inzwischen von Microsoft erhältlich. Allerdings ist es lediglich zur Behebung dieses Problems. Wenden Sie es nur auf Systeme an, bei denen dieses spezielle Problem auftritt. Dieser Hotfix wird möglicherweise noch getestet. Wenn Ihr System durch dieses Problem nicht schwerwiegend beeinträchtigt ist, empfehlen wir, dass Sie warten auf das nächste Servicepack für Microsoft Dynamics NAV 2009 oder die nächste Microsoft Dynamics NAV-Version, die diesen Hotfix enthält.

Hinweis In besonderen Fällen bestimmt Gebühren fallen normalerweise Support aufrufen Wenn Experte Support für Microsoft Dynamics und zugehörige Produkte storniert werden können, dass ein bestimmtes Update Ihr Problem behebt. Die normalen Supportkosten gilt für zusätzliche Supportfragen und Probleme, die nicht für das betreffende Update qualifizieren.

Dieser Hotfix nicht öffentlich zum Download (d. h. eine öffentliche URL für diesen Hotfix nicht in diesem Artikel bereitgestellt wird) gebucht, Verteilung erfordert technische Eskalation Teammitglied oder Genehmigung eines Managers und Folgendes gilt:

  • Um den Hotfix zu erhalten, müssen Kunden den Fehler, der im Abschnitt "Symptome" genannt.

  • Sie müssen die Kunden aufzeichnen zu senden und sie mit dem nächsten Servicepack angeben, wenn es verfügbar wird (wenn ein Servicepack veröffentlicht wird).

Dieser Hotfix wird nicht in einem Microsoft Dynamics NAV Servicepack enthalten sein.



Informationen zur Installation

Microsoft bietet Programmierbeispiele lediglich zur Veranschaulichung, ohne ausdrückliche oder konkludente Gewährleistung. Dies beinhaltet, ist jedoch nicht beschränkt auf, konkludente Gewährleistungen der Tauglichkeit oder Eignung für einen bestimmten Zweck. Dieser Artikel setzt voraus, dass Sie mit der von Beispielen verwendeten Programmiersprache und den Tools, die zum Erstellen und Debuggen von Prozeduren verwendet werden, vertraut sind. Microsoft-Supportmitarbeiter können bei der Erläuterung der Funktionalität bestimmter Prozeduren helfen, sie werden jedoch diese Beispiele nicht verändern um eine erweiterte Funktionalität aufzuzeigen oder Prozeduren entwickeln, die Ihren Anforderungen entsprechen.

Hinweis Bevor Sie diesen Hotfix installieren, stellen Sie sicher, dass alle Microsoft Navision-Clientbenutzer vom System abgemeldet werden. Dies gilt auch für Clientbenutzer der Microsoft Navision Application Services (NAS). Sie sollte nur-Client-Benutzers, der angemeldet ist, wenn Sie diesen Hotfix installieren.

Muss eine Entwicklerlizenz verfügen, um diesen Hotfix installieren können.

Es wird empfohlen, das Benutzerkonto im Fenster Windows-Benutzernamen oder im Fenster Datenbank-Anmeldenamen "SUPER" Rollen-ID zugewiesen werden Wenn das Benutzerkonto die Rollen-ID "SUPER" nicht zugeordnet werden kann, müssen Sie sicherstellen, dass das Benutzerkonto die folgenden Berechtigungen verfügt:

  • Änderungsberechtigung für das Objekt, das Sie ändern.

  • Ausführungsberechtigung für System Object ID 5210 und System Object ID 9015 -Objekt.



Hinweis Sie müssen keinen Datenspeicher Rechte nur Daten zu reparieren.

Ändern von Code

Hinweis Testen Sie Programmcodeverbesserungen generell erst in einem Testsytem, bevor Sie sie im Produktionssystem verwenden.
Gehen Sie folgendermaßen vor, um dieses Problem zu beheben:

  1. Ändern Sie den Code in der Funktion CalcRndDiffAmt in Codeunit "Sales-Post" (80) wie folgt:
    Vorhandener code

    ...// Delete the following lines.
    PROCEDURE CalcRndDiffAmt@1360025(InvAmt@1360007 : Decimal;Currency@1360000 : Record 4) : Decimal;
    BEGIN
    EXIT(CalcTotalAmtInclVAT(Currency) - (InvAmt + CalcPostedAmtInclVAT));
    // End of the lines.

    END;
    ...

    Neuer code

    ...// Add the following lines.
    LOCAL PROCEDURE CalcRndDiffAmt@1360025(InvAmt@1360007 : Decimal;Currency@1360000 : Record 4) : Decimal;
    VAR
    TotalAmtInclVAT@1360001 : Decimal;
    BEGIN
    TotalAmtInclVAT :=
    CalcTotalAmtInclVAT(Currency);
    IF TotalAmtInclVAT = InvAmt THEN
    EXIT(0);
    EXIT(TotalAmtInclVAT - (InvAmt + CalcPostedAmtInclVAT));
    // End of the lines.

    END;
    ...
  2. Ändern Sie den Code in der Funktion IsFinalInvoice in Codeunit "Sales-Post" (80) wie folgt:
    Vorhandener code

    ...SETRANGE("Document No.",SalesHeader."No.");

    // Delete the following line.
    EXIT(SalesPostAdvances.FullyDeductedCustPrepmt(SalesOrderLine));

    END;
    ...

    Neuer code

    ...SETRANGE("Document No.",SalesHeader."No.");

    // Add the following line.
    EXIT(SalesPostAdvances.IsFinalCustInvoice(SalesOrderLine));

    END;
    ...
  3. Ändern Sie den Code in der Funktion CalcRndDiffAmt in der Codeunit "Einkauf-Post" (90) wie folgt:
    Vorhandener code

    ...// Delete the following lines.
    PROCEDURE CalcRndDiffAmt@1360025(InvAmt@1360007 : Decimal;Currency@1360000 : Record 4) : Decimal;
    BEGIN
    EXIT(CalcTotalAmtInclVAT(Currency) - (InvAmt - CalcPostedAmtInclVAT));
    // End of the lines.

    END;
    ...

    Neuer code

    ...// Add the following lines.
    LOCAL PROCEDURE CalcRndDiffAmt@1360025(InvAmt@1360007 : Decimal;Currency@1360000 : Record 4) : Decimal;
    VAR
    TotalAmtInclVAT@1360001 : Decimal;
    BEGIN
    TotalAmtInclVAT :=
    CalcTotalAmtInclVAT(Currency);
    IF TotalAmtInclVAT = InvAmt THEN
    EXIT(0);
    EXIT(TotalAmtInclVAT - (InvAmt - CalcPostedAmtInclVAT));
    // End of the lines.

    END;
    ...
  4. Ändern Sie den Code in der Funktion IsFinalInvoice in der Codeunit "Einkauf-Post" (90) wie folgt:
    Vorhandener code

    ...SETRANGE("Document No.",PurchHeader."No.");

    // Delete the following line.
    EXIT(PurchPostAdvances.FullyDeductedVendPrepmt(PurchOrderLine));

    END;
    ...

    Neuer code

    ...SETRANGE("Document No.",PurchHeader."No.");

    // Add the following line.
    EXIT(PurchPostAdvances.IsFinalVendInvoice(PurchOrderLine));

    END;
    ...
  5. Ändern Sie den Code in der Funktion SalesOrderProcessing in die Codeunit "Vertrieb-Beitrag erhöht" (26585) wie folgt:
    Vorhandener Code 1

    ...VAR

    // Delete the following lines.
    FullyDeducted@1360007 : Boolean;
    DocNoForVATCorr@1360006 : Code[20];
    BEGIN
    WITH SalesHeader DO BEGIN
    FullyDeducted := FullyDeductedCustPrepmt(SalesLine);
    IF FullyDeducted THEN
    // End of the lines.

    InvoicedAmount :=
    ...

    Neuer Code 1

    ...VAR

    // Add the following lines.
    IsFinalInvoice@1360007 : Boolean;
    DocNoForVATCorr@1360006 : Code[20];
    BEGIN
    WITH SalesHeader DO BEGIN
    IsFinalInvoice := IsFinalCustInvoice(SalesLine);
    IF IsFinalInvoice THEN
    // End of the lines.

    InvoicedAmount :=
    ...

    Vorhandener Code 2

    ...SalesLine,SalesInvHeader,LinkedAdvanceEntry,DocNoForVATCorr,

    // Delete the following line.
    FullyDeducted,TempJnlLineDim,InvoicedAmount,Post);

    UNTIL SalesLine.NEXT = 0;
    ...

    Neuer Code 2

    ...SalesLine,SalesInvHeader,LinkedAdvanceEntry,DocNoForVATCorr,

    // Add the following line.
    IsFinalInvoice,TempJnlLineDim,InvoicedAmount,Post);

    UNTIL SalesLine.NEXT = 0;
    ...
  6. Ändern Sie den Code in der Funktion FullyDeductedCustPrepmt in die Codeunit "Vertrieb-Beitrag erhöht" (26585) wie folgt:
    Vorhandener Code 1

    ...// Delete the following line.
    PROCEDURE FullyDeductedCustPrepmt@1470047(VAR SalesLine@1470000 : Record 37) : Boolean;

    BEGIN
    ...

    Neuer Code 1

    ...// Add the following line.
    PROCEDURE IsFinalCustInvoice@1470047(VAR SalesLine@1470000 : Record 37) : Boolean;

    BEGIN
    ...

    Vorhandener Code 2

    ...SetSalesLineToPost(SalesLine);

    // Delete the following line.
    IF SalesLine."Prepmt Amt to Deduct" + SalesLine."Prepmt Amt Deducted" <> SalesLine."Prepmt. Amt. Inv." THEN

    EXIT(FALSE);
    ...

    Neuer Code 2

    ...SetSalesLineToPost(SalesLine);

    // Add the following line.
    IF SalesLine."Qty. to Invoice" + SalesLine."Quantity Invoiced" <> SalesLine.Quantity THEN

    EXIT(FALSE);
    ...
  7. Ändern Sie den Code in der Funktion CollectFullyDeductedOrders in die Codeunit "Vertrieb-Beitrag erhöht" (26858) wie folgt:
    Vorhandener Code 1

    ...TempSalesOrderLine@1360003 : TEMPORARY Record 37;

    // Delete the following line.
    FullyDeducted@1360004 : Boolean;

    BEGIN
    ...

    Neuer Code 1

    ...TempSalesOrderLine@1360003 : TEMPORARY Record 37;

    // Add the following line.
    IsFinalInvoice@1360004 : Boolean;

    BEGIN
    ...

    Vorhandener Code 2

    ...FilterSalesOrderLineWithHeader(SalesOrderLine,FullyDeductedOrder);

    // Delete the following lines.
    FullyDeducted := FullyDeductedOrder.FIND;
    IF NOT FullyDeducted THEN BEGIN
    FullyDeducted := FullyDeductedCustPrepmt(SalesOrderLine);
    IF FullyDeducted THEN
    FullyDeductedOrder.INSERT;
    END;
    IF FullyDeducted THEN BEGIN
    // End of the lines.

    FillSalesOrderLineFromSalesInv(TempSalesOrderLine,SalesOrderLine);
    ...

    Neuer Code 2

    ...FilterSalesOrderLineWithHeader(SalesOrderLine,FullyDeductedOrder);

    // Add the following lines.
    IsFinalInvoice := FullyDeductedOrder.FIND;
    IF NOT IsFinalInvoice THEN BEGIN
    IsFinalInvoice := IsFinalCustInvoice(SalesOrderLine);
    IF IsFinalInvoice THEN
    FullyDeductedOrder.INSERT;
    END;
    IF IsFinalInvoice THEN BEGIN
    // End of the lines.

    FillSalesOrderLineFromSalesInv(TempSalesOrderLine,SalesOrderLine);
    ...
  8. Ändern Sie den Code in der Funktion PurchOrderProcessing in der Codeunit "Purchace-Post setzt" (26586) wie folgt:
    Vorhandener Code 1

    ...VAR

    // Delete the following lines.
    FullyDeducted@1360007 : Boolean;
    DocNoForVATCorr@1360006 : Code[20];
    BEGIN
    WITH PurchHeader DO BEGIN
    FullyDeducted := FullyDeductedVendPrepmt(PurchLine);
    IF FullyDeducted THEN
    // End of the lines.

    InvoicedAmount :=
    ...

    Neuer Code 1

    ...VAR

    // Add the following lines.
    IsFinalInvoice@1360007 : Boolean;
    DocNoForVATCorr@1360006 : Code[20];
    BEGIN
    WITH PurchHeader DO BEGIN
    IsFinalInvoice := IsFinalVendInvoice(PurchLine);
    IF IsFinalInvoice THEN
    // End of the lines.

    InvoicedAmount :=
    ...

    Vorhandener Code 2

    ...PurchLine,PurchInvHeader,LinkedAdvanceEntry,DocNoForVATCorr,

    // Delete the following line.
    FullyDeducted,TempJnlLineDim,InvoicedAmount,Post);

    UNTIL PurchLine.NEXT = 0;
    ...

    Neuer Code 2

    ...PurchLine,PurchInvHeader,LinkedAdvanceEntry,DocNoForVATCorr,

    // Add the following line.
    IsFinalInvoice,TempJnlLineDim,InvoicedAmount,Post);

    UNTIL PurchLine.NEXT = 0;
    ...
  9. Ändern Sie den Code in der Funktion FullyDeductedVendPrepmt in der Codeunit "Purchace-Post setzt" (26586) wie folgt:
    Vorhandener Code 1

    ...// Delete the following line.
    PROCEDURE FullyDeductedVendPrepmt@1470047(VAR PurchLine@1470000 : Record 39) : Boolean;

    BEGIN
    ...

    Neuer Code 1

    ...// Add the following line.
    PROCEDURE IsFinalVendInvoice@1470047(VAR PurchLine@1470000 : Record 39) : Boolean;

    BEGIN
    ...

    Vorhandener Code 2

    ...SetPurchLineToPost(PurchLine);

    // Delete the following line.
    IF PurchLine."Prepmt Amt to Deduct" + PurchLine."Prepmt Amt Deducted" <> PurchLine."Prepmt. Amt. Inv." THEN

    EXIT(FALSE);
    ...

    Neuer Code 2

    ...SetPurchLineToPost(PurchLine);

    // Add the following line.
    IF PurchLine."Qty. to Invoice" + PurchLine."Quantity Invoiced" <> PurchLine.Quantity THEN

    EXIT(FALSE);
    ...
  10. Ändern Sie den Code in der Funktion CollectFullyDeductedOrders in der Codeunit "Purchace-Post setzt" (26586) wie folgt:
    Vorhandener Code 1

    ...TempPurchOrderLine@1360003 : TEMPORARY Record 39;

    // Delete the following line.
    FullyDeducted@1360004 : Boolean;

    BEGIN
    ...

    Neuer Code 1

    ...TempPurchOrderLine@1360003 : TEMPORARY Record 39;

    // Add the following line.
    IsFinalInvoice@1360004 : Boolean;

    BEGIN
    ...

    Vorhandener Code 2

    ...FilterPurchOrderLineWithHeader(PurchOrderLine,FullyDeductedOrder);

    // Delete the following lines.
    FullyDeducted := FullyDeductedOrder.FIND;
    IF NOT FullyDeducted THEN BEGIN
    FullyDeducted := FullyDeductedVendPrepmt(PurchOrderLine);
    IF FullyDeducted THEN
    FullyDeductedOrder.INSERT;
    END;
    IF FullyDeducted THEN BEGIN
    // End of the lines.

    FillPurchOrderLineFromPurchInv(TempPurchOrderLine,PurchOrderLine);
    ...

    Neuer Code 2

    ...FilterPurchOrderLineWithHeader(PurchOrderLine,FullyDeductedOrder);

    // Add the following lines.
    IsFinalInvoice := FullyDeductedOrder.FIND;
    IF NOT IsFinalInvoice THEN BEGIN
    IsFinalInvoice := IsFinalVendInvoice(PurchOrderLine);
    IF IsFinalInvoice THEN
    FullyDeductedOrder.INSERT;
    END;
    IF IsFinalInvoice THEN BEGIN
    // End of the lines.

    FillPurchOrderLineFromPurchInv(TempPurchOrderLine,PurchOrderLine);
    ...

Voraussetzungen

Ungarische Version von Microsoft Dynamics NAV 2009 R2 mit Vorauszahlung Update verfügen, um diesen Hotfix installieren müssen.

Informationen zur Deinstallation

Dieser Hotfix kann nicht entfernt werden.

Referenzen

VSTF DynamicsNAVSE: 331403

Status

Microsoft hat bestätigt, dass es sich um ein Problem bei den Microsoft-Produkten handelt, die im Abschnitt „Eigenschaften“ aufgeführt sind.

Hinweis Dies ist ein im Schnellverfahren veröffentlichter Artikel, der direkt in der Microsoft Support-Organisation erstellt wurde. Die hierin enthaltenen Informationen werden ohne Mängelgewähr in Reaktion auf neue Probleme bereitgestellt. Aufgrund der schnellen Bereitstellung kann das Material möglicherweise typografische Fehler enthalten und jederzeit ohne vorherige Ankündigung geändert werden. Weitere Hinweise finden Sie unter Geschäftsbedingungen .

Autor: Andregu
Ersteller: V-deni
Technische Überprüfung: Andregu
Redaktion:

Benötigen Sie weitere Hilfe?

Ihre Office-Fähigkeiten erweitern
Schulungen erkunden
Neue Funktionen als Erster erhalten
Microsoft Insider beitreten

War diese Information hilfreich?

Vielen Dank für Ihr Feedback!

Vielen Dank für Ihr Feedback. Es klingt, als ob es hilfreich sein könnte, Sie mit einem unserer Office-Supportmitarbeiter zu verbinden.

×