CONSISTENT-Fehler, wenn Sie in der spanischen Version von Microsoft Dynamics NAV 2009 eine Rechnung im Cartera-Journal im Verkauf buchen
Wenn Sie versuchen, in der spanischen Version von Microsoft Dynamics NAV 2009 eine Rechnung im Cartera-Journal mit der Seite „Währung im Verkauf" zu buchen, erhalten Sie die folgende Fehlermeldung:
„Die Transaktion kann nicht abgeschlossen werden, da dies zu Inkonsistenzen in der Hauptbucheintragstabelle führt. Überprüfen Sie, wo und wie die CONSISTENT-Funktion in der Transaktion verwendet wird, um die Ursache für den Fehler zu finden. Wenden Sie sich an Ihren Systemadministrator. Tabellen können als inkonsistent markiert werden bei umfangreichen Aufgaben, wie z.B. Buchungen. Dadurch wird verhindert, dass Daten fehlerhaft aktualisiert werden."
Dies geschieht nur, wenn „Zusätzliche Berichtswährung"=Währung. Befolgen Sie die Schritte im Abschnitt „Codeänderungen", um dieses Problem zu beheben. Dieses Problem tritt bei folgendem Produkt auf:
Die spanische Version von Microsoft Dynamics NAV 2009 R2
Die spanische Version von Microsoft Dynamics NAV 2009 SP1
Auflösung
Hotfix-Informationen
Ein unterstützter Hotfix ist jetzt von Microsoft verfügbar. Es dient jedoch lediglich der Behebung des in diesem Artikel beschriebenen Problems. Wenden Sie es nur auf Systeme an, bei denen dieses spezielle Problem auftritt. Dieser Hotfix wird möglicherweise weiteren Tests unterzogen. Wenn Sie von diesem Problem nicht schwerwiegend betroffen sind, empfehlen wir Ihnen daher, auf das nächste Microsoft Dynamics NAV 2009 Service Pack oder die nächste Microsoft Dynamics NAV-Version zu warten, die diesen Hotfix enthält.
Hinweis: In besonderen Fällen können die Gebühren, die normalerweise für Supportanrufe anfallen, storniert werden, wenn ein Mitarbeiter des technischen Supports für Microsoft Dynamics und verwandte Produkte feststellt, dass ein bestimmtes Update Ihr Problem lösen wird. Für zusätzliche Supportfragen und Probleme, die für das jeweilige Update nicht in Frage kommen, fallen die üblichen Supportkosten an.
Installationsinformationen
Microsoft stellt Programmierbeispiele nur zur Veranschaulichung zur Verfügung, ohne ausdrückliche oder stillschweigende Gewährleistung. Dazu gehören unter anderem stillschweigende Garantien der Marktgängigkeit oder Eignung für einen bestimmten Zweck. In diesem Artikel wird davon ausgegangen, dass Sie mit der demonstrierten Programmiersprache und den Tools vertraut sind, die zum Erstellen und Debuggen von Prozeduren verwendet werden. Microsoft-Supporttechniker können dabei helfen, die Funktionalität eines bestimmten Verfahrens zu erläutern. Sie werden diese Beispiele jedoch nicht ändern, um zusätzliche Funktionalität bereitzustellen oder Prozeduren zu erstellen, die Ihren spezifischen Anforderungen entsprechen.
Hinweis Bevor Sie diesen Hotfix installieren, stellen Sie sicher, dass alle Benutzer des Microsoft Dynamics NAV-Clients vom System abgemeldet sind. Dazu gehören Microsoft Dynamics NAV Application Server (NAS)-Dienste. Sie sollten der einzige Clientbenutzer sein, der angemeldet ist, wenn Sie diesen Hotfix implementieren.
Um diesen Hotfix zu implementieren, benötigen Sie eine Entwicklerlizenz.
Wir empfehlen, dem Benutzerkonto im Fenster „Windows-Anmeldungen" oder im Fenster „Datenbank-Anmeldungen" die Rollen-ID „SUPER" zuzuweisen. Wenn dem Benutzerkonto nicht die Rollen-ID „SUPER" zugewiesen werden kann, müssen Sie überprüfen, ob das Benutzerkonto über die folgenden Berechtigungen verfügt:
Die Änderungsberechtigung für das Objekt, das Sie ändern möchten.
Die Ausführungsberechtigung für das Systemobjekt-ID-5210-Objekt und für das Systemobjekt-ID-9015-Objekt
Objekt.
Hinweis Sie müssen keine Rechte an den Datenspeichern haben, es sei denn, Sie müssen eine Datenreparatur durchführen.
Codeänderungen
Hinweis: Testen Sie Codekorrekturen immer in einer kontrollierten Umgebung, bevor Sie die Korrekturen auf Ihren Produktionscomputern anwenden. Bevor Sie die Änderung anwenden, importieren Sie bitte alle SEPA-Updates.
Um dieses Problem zu beheben, ändern Sie den Code in der PostReceivableDocs-Funktion in der Gen. Jnl.-Post Line Codeunit (12) wie folgt:
Vorhandener Code 1
...
END;
LOCAL PROCEDURE PostReceivableDocs@1100003(EntryUnapplied@1100001 : Boolean);
BEGIN
// es0012.begin
IF (DocAmountLCY <> 0) OR (DiscDocAmountLCY <> 0) OR (CollDocAmountLCY <> 0) OR (RejDocAmountLCY <> 0) OR
...
Ersatzcode 1
...
END;
LOCAL PROCEDURE PostReceivableDocs@1100003(EntryUnapplied@1100001 : Boolean);
// Add the following lines.
VAR
DocAmountAddCurr@1100003 : Decimal;
// End of the added lines.
BEGIN
// es0012.begin
IF (DocAmountLCY <> 0) OR (DiscDocAmountLCY <> 0) OR (CollDocAmountLCY <> 0) OR (RejDocAmountLCY <> 0) OR
...
Vorhandener Code 2
...
NextEntryNo := NextEntryNo - 1;
// es0012.end
IF DocAmountLCY <> 0 THEN BEGIN
IF (GenJnlLine."Applies-to Doc. Type" = GenJnlLine."Applies-to Doc. Type"::Invoice) OR
EntryUnapplied
THEN BEGIN
...
Ersatzcode 2
...
NextEntryNo := NextEntryNo - 1;
// es0012.end
IF DocAmountLCY <> 0 THEN BEGIN
// Add the following lines.
IF GenJnlLine."Currency Code" = AddCurrency.Code THEN
DocAmountAddCurr := GenJnlLine.Amount
ELSE
DocAmountAddCurr := DocAmtCalcAddCurrency(DocAmountLCY);
// End of the added lines.
IF (GenJnlLine."Applies-to Doc. Type" = GenJnlLine."Applies-to Doc. Type"::Invoice) OR
EntryUnapplied
THEN BEGIN...
Vorhandener Code 3
...
EntryUnapplied
THEN BEGIN
CustPostingGr.TESTFIELD("Receivables Account");
// Delete the following line.
InitGLEntry(CustPostingGr."Receivables Account",DocAmountLCY,DocAmtCalcAddCurrency(DocAmountLCY),TRUE,TRUE);
// End of the deleted line.
GLEntry."Bal. Account Type" := GenJnlLine."Bal. Account Type";
GLEntry."Bal. Account No." := GenJnlLine."Bal. Account No.";
InsertGLEntry(TRUE);
...
Ersatzcode 3
...
EntryUnapplied
THEN BEGIN
CustPostingGr.TESTFIELD("Receivables Account");
// Add the following line.
InitGLEntry(CustPostingGr."Receivables Account",DocAmountLCY,DocAmountAddCurr,TRUE,TRUE);
// End of the added line.
GLEntry."Bal. Account Type" := GenJnlLine."Bal. Account Type";
GLEntry."Bal. Account No." := GenJnlLine."Bal. Account No.";
InsertGLEntry(TRUE);
...
Vorhandener Code 4
...
InsertGLEntry(TRUE);
END ELSE BEGIN
CustPostingGr.TESTFIELD("Bills Account");
// Delete the following line.
InitGLEntry(CustPostingGr."Bills Account",DocAmountLCY,DocAmtCalcAddCurrency(DocAmountLCY),TRUE,TRUE);
// End of the deleted line.
GLEntry."Bal. Account Type" := GenJnlLine."Bal. Account Type";
GLEntry."Bal. Account No." := GenJnlLine."Bal. Account No.";
InsertGLEntry(TRUE);
...
Ersatzcode 4
...
InsertGLEntry(TRUE);
END ELSE BEGIN
CustPostingGr.TESTFIELD("Bills Account");
// Add the following line.
InitGLEntry(CustPostingGr."Bills Account",DocAmountLCY,DocAmountAddCurr,TRUE,TRUE);
// End of the added line.
GLEntry."Bal. Account Type" := GenJnlLine."Bal. Account Type";
GLEntry."Bal. Account No." := GenJnlLine."Bal. Account No.";
InsertGLEntry(TRUE);
...
Voraussetzungen
Um diesen Hotfix anwenden zu können, muss eines der folgenden Produkte installiert sein:
Die spanische Version von Microsoft Dynamics NAV 2009 R2
Die spanische Version von Microsoft Dynamics NAV 2009 SP1
Informationen zum Entfernen
Sie können diesen Hotfix nicht entfernen.
Status
Microsoft hat bestätigt, dass es sich hierbei um ein Problem bei den Microsoft-Produkten handelt, die im Abschnitt „Gilt für" aufgeführt sind.
Hinweis Dies ist ein „FAST PUBLISH"-Artikel, der direkt von der Microsoft-Supportorganisation erstellt wurde. Die hierin enthaltenen Informationen werden unverändert als Reaktion auf neu auftretende Probleme bereitgestellt. Aufgrund der schnellen Bereitstellung können die Materialien Tippfehler enthalten und jederzeit ohne Vorankündigung überarbeitet werden. Weitere Hinweise finden Sie in den Nutzungsbedingungen .
No comments:
Post a Comment