Aanmelden met Microsoft
Meld u aan of maak een account.
Hallo,
Selecteer een ander account.
U hebt meerdere accounts
Kies het account waarmee u zich wilt aanmelden.

Wanneer u posten in de kaart van de klant of leverancier in de Portugese versie van Microsoft Dynamics NAV 2009 klant of leverancier, wordt een onjuiste G/L register record die naar een niet-bestaande record voor de grootboekposten verwijst gemaakt. Volg de stappen in de sectie codewijzigingen oplossen van dit probleem. Dit probleem treedt op in de volgende producten:

  • De Portugese versie van Microsoft Dynamics NAV 2009 R2

  • De Portugese versie van Microsoft Dynamics NAV 2009 SP1

Oplossing

Informatie over de hotfix

Een ondersteunde hotfix is nu beschikbaar bij Microsoft. Het is echter alleen bedoeld om het probleem dat wordt beschreven in dit artikel. Pas deze alleen toe op systemen waarop dit specifieke probleem zich voordoet. Deze hotfix moet wellicht extra worden getest. Als u geen ernstige problemen ondervindt, is het daarom raadzaam te wachten op het volgende servicepack voor Microsoft Dynamics NAV 2009 of de volgende Microsoft Dynamics NAV versie waarin deze hotfix is opgenomen.

Opmerking In speciale gevallen kunnen kosten die verbonden zijn aan ondersteuningsoproepen ondersteuning worden geannuleerd als een medewerker van Technical Support voor Microsoft Dynamics en verwante producten bepaalt dat een specifieke update de oplossing van uw probleem. De normale ondersteuningskosten blijven gelden voor extra ondersteuningsvragen die niet in aanmerking voor de specifieke update in kwestie komen.

Informatie over de installatie

Microsoft verstrekt programmeervoorbeelden uitsluitend ter illustratie, zonder expliciete of impliciete garantie. Dit omvat, maar is niet beperkt tot, de impliciete garanties van verkoopbaarheid of geschiktheid voor een bepaald doel. In dit artikel wordt ervan uitgegaan dat u bekend met de programmeertaal die wordt aangetoond en met de hulpprogramma's die worden gebruikt bent voor het maken van en naar procedures voor foutopsporing. Ondersteuningstechnici van Microsoft kunnen voor uitleg over de functionaliteit van een bepaalde procedure. Zij zal deze voorbeelden bieden extra functionaliteit of desgewenst uw specifieke vereisten echter niet wijzigen.

Opmerking Voordat u deze hotfix hebt geïnstalleerd, controleert u of dat alle gebruikers van Microsoft Dynamics NAV-clients zijn afgemeld bij het systeem. Dit omvat services voor Microsoft Dynamics NAV Application Server (NAS). U moet de alleen clientgebruiker die is aangemeld wanneer u deze hotfix gaat implementeren.

Als u deze hotfix gaat implementeren, hebt u een ontwikkelaarslicentie voor.

Is raadzaam dat de gebruikersaccount in het venster Windows-aanmeldingen of Databaseaanmeldingen de rol-id 'SUPER'. Als de gebruikersaccount kan worden toegewezen als de ID 'SUPER' rol, moet u controleren of de gebruikersaccount de volgende machtigingen heeft:

  • De machtiging wijzigen voor het object dat u wijzigt.

  • De machtiging uitvoeren voor het object System Object ID 5210 en voor de System Object ID 9015

    -object.

Opmerking Er geen rechten voor de opgeslagen gegevens hebben, tenzij u gegevens herstellen.

Codewijzigingen

Opmerking test correcties altijd in een testomgeving voordat u ze implementeert in de productieomgeving. Importeer alle SEPA updates voordat de wijziging wordt toegepast.

U kunt dit probleem oplossen door de volgende stappen uit te voeren:

  1. Wijzig de code in de functie PostDtldCustLedgEntries in Alg. verz.-regel Codeunit boeken (12) als volgt:
    Bestaande code 1

    ...SavedEntryUsed@1023 : Boolean;
    ReceivableAccAmtLCY@1110107 : Decimal;
    ReceivableAccAmtAddCurr@1110108 : Decimal;
    DtldCustLedgEntry2@1110109 : TEMPORARY Record 379;
    ExistDtldCVLedgEntryBuf@1110110 : Boolean;
    BEGIN
    TotalAmountLCY := 0;
    TotalAmountAddCurr := 0;
    PositiveLCYAppAmt := 0;
    PositiveACYAppAmt := 0;
    ...

    Nieuwe code 1

    ...SavedEntryUsed@1023 : Boolean;
    ReceivableAccAmtLCY@1110107 : Decimal;
    ReceivableAccAmtAddCurr@1110108 : Decimal;
    DtldCustLedgEntry2@1110109 : TEMPORARY Record 379;
    ExistDtldCVLedgEntryBuf@1110110 : Boolean;

    // Add the following line.
    FindBill@1100004 : Boolean;
    // End of the added line.

    BEGIN
    TotalAmountLCY := 0;
    TotalAmountAddCurr := 0;
    PositiveLCYAppAmt := 0;
    PositiveACYAppAmt := 0;
    ...

    Bestaande code 2

    ...IF DtldCustLedgEntry.FINDLAST THEN
    DtldCustLedgEntryNoOffset := DtldCustLedgEntry."Entry No."
    ELSE
    DtldCustLedgEntryNoOffset := 0;
    DtldCVLedgEntryBuf.RESET;

    // Delete the following lines.
    IF DtldCVLedgEntryBuf.FINDSET THEN BEGIN
    SaveEntryNo := NextEntryNo;
    NextEntryNo := NextEntryNo + 1;
    NextEntryNo2 := NextEntryNo;
    // End of the deleted lines.

    REPEAT
    IF DtldCVLedgEntryBuf."Posting Date" <> GenJnlLine."Posting Date" THEN BEGIN
    OriginalPostingDate := GenJnlLine."Posting Date";
    GenJnlLine."Posting Date" := DtldCVLedgEntryBuf."Posting Date";
    OriginalDateSet := TRUE;
    ...

    Vervangende code 2

    ...IF DtldCustLedgEntry.FINDLAST THEN
    DtldCustLedgEntryNoOffset := DtldCustLedgEntry."Entry No."
    ELSE
    DtldCustLedgEntryNoOffset := 0;
    DtldCVLedgEntryBuf.RESET;

    // Add the following lines.
    DtldCVLedgEntryBuf.SETRANGE("Initial Document Type",DtldCVLedgEntryBuf."Initial Document Type"::Bill);
    IF NOT DtldCVLedgEntryBuf.ISEMPTY THEN
    FindBill := TRUE;
    DtldCVLedgEntryBuf.RESET;
    IF DtldCVLedgEntryBuf.FINDSET THEN BEGIN
    IF CustLedgEntryInserted OR FindBill THEN BEGIN
    SaveEntryNo := NextEntryNo;
    NextEntryNo := NextEntryNo + 1;
    NextEntryNo2 := NextEntryNo;
    END;
    // End of the added lines.

    REPEAT
    IF DtldCVLedgEntryBuf."Posting Date" <> GenJnlLine."Posting Date" THEN BEGIN
    OriginalPostingDate := GenJnlLine."Posting Date";
    GenJnlLine."Posting Date" := DtldCVLedgEntryBuf."Posting Date";
    OriginalDateSet := TRUE;
    ...

    Bestaande code 3

    ...SavedEntryUsed@1031 : Boolean;
    PayableAccAmtLCY@1110120 : Decimal;
    PayableAccAmtAddCurr@1110121 : Decimal;
    DtldVendLedgEntry2@1110122 : Record 380;
    ExistDtldCVLedgEntryBuf@1110123 : Boolean;
    BEGIN
    TotalAmountLCY := 0;
    TotalAmountAddCurr := 0;
    PositiveLCYAppAmt := 0;
    PositiveACYAppAmt := 0;
    ...

    Vervangende code 3

    ...SavedEntryUsed@1031 : Boolean;
    PayableAccAmtLCY@1110120 : Decimal;
    PayableAccAmtAddCurr@1110121 : Decimal;
    DtldVendLedgEntry2@1110122 : Record 380;
    ExistDtldCVLedgEntryBuf@1110123 : Boolean;

    // Add the following line.
    FindBill@1100005 : Boolean;
    // End of the added line.

    BEGIN
    TotalAmountLCY := 0;
    TotalAmountAddCurr := 0;
    PositiveLCYAppAmt := 0;
    PositiveACYAppAmt := 0;
    ...

    Bestaande code 4

    ... IF GenJnlLine2."Account Type" = GenJnlLine2."Account Type"::Vendor THEN BEGIN
    IF DtldVendLedgEntry.FINDLAST THEN
    DtldVendLedgEntryNoOffset := DtldVendLedgEntry."Entry No."
    ELSE
    DtldVendLedgEntryNoOffset := 0;

    // Delete the following lines.

    DtldCVLedgEntryBuf.RESET;
    IF DtldCVLedgEntryBuf.FINDSET THEN BEGIN
    SaveEntryNo := NextEntryNo;
    NextEntryNo := NextEntryNo + 1;
    NextEntryNo2 := NextEntryNo;
    // End of the deleted lines.

    REPEAT
    IF DtldCVLedgEntryBuf."Posting Date" <> GenJnlLine."Posting Date" THEN BEGIN
    OriginalPostingDate := GenJnlLine."Posting Date";
    GenJnlLine."Posting Date" := DtldCVLedgEntryBuf."Posting Date";
    OriginalDateSet := TRUE;
    ...

    Vervangende code 4

    ...IF GenJnlLine2."Account Type" = GenJnlLine2."Account Type"::Vendor THEN BEGIN
    IF DtldVendLedgEntry.FINDLAST THEN
    DtldVendLedgEntryNoOffset := DtldVendLedgEntry."Entry No."
    ELSE
    DtldVendLedgEntryNoOffset := 0;

    // Add the following lines.
    DtldCVLedgEntryBuf.RESET;
    DtldCVLedgEntryBuf.SETRANGE("Initial Document Type",DtldCVLedgEntryBuf."Initial Document Type"::Bill);
    IF NOT DtldCVLedgEntryBuf.ISEMPTY THEN
    FindBill := TRUE;

    DtldCVLedgEntryBuf.RESET;
    IF DtldCVLedgEntryBuf.FINDSET THEN BEGIN
    IF VendLedgEntryInserted OR FindBill THEN BEGIN
    SaveEntryNo := NextEntryNo;
    NextEntryNo := NextEntryNo + 1;
    NextEntryNo2 := NextEntryNo;
    END;
    // End of the added lines.

    REPEAT
    IF DtldCVLedgEntryBuf."Posting Date" <> GenJnlLine."Posting Date" THEN BEGIN
    OriginalPostingDate := GenJnlLine."Posting Date";
    GenJnlLine."Posting Date" := DtldCVLedgEntryBuf."Posting Date";
    OriginalDateSet := TRUE;
    ...

Vereisten

Hebt u een van de volgende producten geïnstalleerd om deze hotfix:

  • De Portugese versie van Microsoft Dynamics NAV 2009 R2

  • De Portugese versie van Microsoft Dynamics NAV 2009 SP1

Informatie over verwijderen

U kunt deze hotfix niet verwijderen.

Status

Microsoft heeft bevestigd dat dit probleem kan optreden in de Microsoft-producten die worden vermeld in de sectie 'Van toepassing op'.

Opmerking Dit is een 'Snel publiceren' artikel dat rechtstreeks door het ondersteuningsteam van Microsoft is gemaakt. De informatie wordt geleverd zoals het is in reactie op de opkomende problemen. Omdat het artikel snel beschikbaar moest zijn, kunnen de materialen typografische fouten bevatten en op elk gewenst moment zonder voorafgaande kennisgeving worden gewijzigd. Zie de Gebruiksvoorwaardenvoor andere overwegingen.

Meer hulp nodig?

Meer opties?

Verken abonnementsvoordelen, blader door trainingscursussen, leer hoe u uw apparaat kunt beveiligen en meer.

Community's helpen u vragen te stellen en te beantwoorden, feedback te geven en te leren van experts met uitgebreide kennis.

Was deze informatie nuttig?

Hoe tevreden bent u met de taalkwaliteit?
Wat heeft uw ervaring beïnvloed?
Als u op Verzenden klikt, wordt uw feedback gebruikt om producten en services van Microsoft te verbeteren. Uw IT-beheerder kan deze gegevens verzamelen. Privacyverklaring.

Hartelijk dank voor uw feedback.

×