Dit artikel is van toepassing op Microsoft Dynamics NAV voor alle landen en alle taalinstellingen.
Symptomen
Wanneer u een upgrade uitvoert van Microsoft Dynamics NAV 2009 voor Dynamics NAV 2013 het veld vooruitbetaling. BTW-bedrag facturen (LV) veld ontbreekt in de verkoop- en inkoopregels. Als een vooruitbetalingsfactuur wordt geboekt voordat de upgrade wordt uitgevoerd en u probeert te maken van een creditnota voor de vooruitbetalingsfactuur, bericht u een inconsistentie bij het boeken van de vooruitbetalingscreditnota.
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 2013 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 Altijd test code worden opgelost in een testomgeving voordat u de correcties in de productieomgeving.
U kunt dit probleem oplossen door de volgende stappen uit te voeren:
-
De code in de functie bijwerken in de Upgrade nieuwe versie Codeunit (104048 uitvoeren) als volgt wijzigen:
Bestaande code...UpdateItemLedgerEntry(StateIndicator);
UpdateDOCreditCard(StateIndicator);
UpdateSalesOrderDate(StateIndicator);
UpdateOutlookSynchFilter(StateIndicator);
UpdateOutlookSynchField(StateIndicator);
DeleteRemovedPermissions(StateIndicator);
...Nieuwe code
...UpdateItemLedgerEntry(StateIndicator);
UpdateDOCreditCard(StateIndicator);
UpdateSalesOrderDate(StateIndicator);
// Add the following lines.
UpdateSalesLines(StateIndicator);
UpdatePurchLines(StateIndicator);
// End of the added lines.
UpdateOutlookSynchFilter(StateIndicator);
UpdateOutlookSynchField(StateIndicator);
DeleteRemovedPermissions(StateIndicator);
... -
Voeg de volgende functies:
LOCAL PROCEDURE UpdateSalesLines@62(VAR StateIndicator@1000 : Record 104037);VAR
SalesLine@1001 : Record 37;
LastDocumentNo@1002 : Code[20];
PrepmtInvReminderAmount@1003 : Decimal;
BEGIN
WITH SalesLine DO
IF StateIndicator.UpdateTable(TABLENAME) THEN BEGIN
TimeLog.TimeLogInsert(TimeLog,TABLENAME,TRUE);
SETCURRENTKEY("Document Type","Document No.","Line No.");
IF FINDSET THEN
REPEAT
StateIndicator.Update;
IF ("Document Type" = "Document Type"::Order) AND ("Prepayment Amount" <> "Prepmt. Amt. Incl. VAT") THEN BEGIN
IF "Document No." <> LastDocumentNo THEN BEGIN
LastDocumentNo := "Document No.";
PrepmtInvReminderAmount := 0;
END;
IF ("Prepmt. Amount Inv. (LCY)" <> 0) AND ("Prepmt. VAT Amount Inv. (LCY)" = 0) THEN BEGIN
"Prepmt. VAT Amount Inv. (LCY)" :=
CalcRndedAmount("Prepmt. Amount Inv. (LCY)","Prepayment VAT %" / 100,PrepmtInvReminderAmount);
MODIFY;
END;
END;
UNTIL NEXT = 0;
TimeLog.TimeLogInsert(TimeLog,TABLENAME,FALSE);
StateIndicator.EndUpdateTable(TABLENAME);
END;
LOCAL PROCEDURE UpdatePurchLines@63(VAR StateIndicator@1000 : Record 104037);
VAR
PurchaseLine@1001 : Record 39;
LastDocumentNo@1002 : Code[20];
PrepmtInvReminderAmount@1003 : Decimal;
BEGIN
WITH PurchaseLine DO
IF StateIndicator.UpdateTable(TABLENAME) THEN BEGIN
TimeLog.TimeLogInsert(TimeLog,TABLENAME,TRUE);
IF FINDSET THEN
REPEAT
StateIndicator.Update;
IF ("Document Type" = "Document Type"::Order) AND ("Prepayment Amount" <> "Prepmt. Amt. Incl. VAT") THEN BEGIN
IF "Document No." <> LastDocumentNo THEN BEGIN
LastDocumentNo := "Document No.";
PrepmtInvReminderAmount := 0;
END;
IF ("Prepmt. Amount Inv. (LCY)" <> 0) AND ("Prepmt. VAT Amount Inv. (LCY)" = 0) THEN BEGIN
"Prepmt. VAT Amount Inv. (LCY)" :=
CalcRndedAmount("Prepmt. Amount Inv. (LCY)","Prepayment VAT %" / 100,PrepmtInvReminderAmount);
MODIFY;
END;
END;
UNTIL NEXT = 0;
TimeLog.TimeLogInsert(TimeLog,TABLENAME,FALSE);
StateIndicator.EndUpdateTable(TABLENAME);
END;
LOCAL PROCEDURE CalcRndedAmount@64(LineAmount@1000 : Decimal;Ratio@1001 : Decimal;VAR Reminder@1002 : Decimal) RndedAmount : Decimal;
VAR
Amount@1003 : Decimal;
BEGIN
Amount := Reminder + LineAmount * Ratio;
RndedAmount := ROUND(Amount);
Reminder := Amount - RndedAmount;
END;
Vereisten
U moet Microsoft Dynamics NAV 2013 hebben geïnstalleerd om deze hotfix te kunnen hebben.
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.