När du använder valuta i Microsoft Dynamics NAV 2009 tillämpat belopp beräknas felaktigt i Använd kund eller använda leverantör poster sidor om du använder en betalning i valutan för fakturor i lokal valuta. Det här problemet uppstår i följande produkter:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 servicepack 1 (SP1)
Lösning
Information om snabbkorrigeringen
En snabbkorrigering är nu tillgänglig från Microsoft. Den är endast avsedd att åtgärda det problem som beskrivs i denna artikel. Använd den bara på datorer där detta problem uppstår. Snabbkorrigeringen kan komma att testas igen. Om inte störs alltför mycket av detta problem rekommenderar vi att du väntar på Nästa service pack-versionen för Microsoft Dynamics NAV 2009 eller nästa Microsoft Dynamics NAV-version som innehåller den här snabbkorrigeringen.
Obs! I särskilda fall, de avgifter som är normalt för support vara avgiftsfri om en supporttekniker för Microsoft Dynamics och relaterade produkter som bestämmer att en särskild uppdatering kan lösa ditt problem. De vanliga supportkostnaderna gäller för övriga supportfrågor och problem som inte berör den särskilda uppdateringen.
Installationsinformation
Microsoft tillhandahåller programmeringsexempel endast utan garanti varken uttryckliga eller underförstådda. Detta inkluderar men är inte begränsat till, underförstådda garantier om säljbarhet eller lämplighet för ett särskilt ändamål. Den här artikeln förutsätter att du är bekant med det programmeringsspråk som demonstreras och de verktyg som används för att skapa och felsöka procedurer. Microsofts supporttekniker kan hjälpa till att förklara funktionen hos en viss procedur. De kommer inte ändra dessa exempel för att ge ytterligare funktioner eller skapa procedurer som motsvarar dina speciella behov.
Obs! Innan du installerar den här snabbkorrigeringen måste du kontrollera att alla användare i Microsoft Dynamics NAV-klienten har loggat ut. Detta omfattar tjänster för Microsoft Dynamics NAV Application Server (NAS). Du ska endast klientanvändare som är inloggad när du implementerar den här snabbkorrigeringen.
Om du vill genomföra den här snabbkorrigeringen måste du ha en utvecklarlicens.
Vi rekommenderar att tilldelas användarkontot i fönstret Windows-inloggningar eller i fönstret databasinloggningar "SUPER" roll-ID. Om användarkontot inte kan tilldelas "SUPER" roll-ID måste du kontrollera att användarkontot har följande behörigheter:
-
Ändra behörighet för objektet ändras.
-
Körbehörighet för systemet objektet ID 5210 objekt och System objektet ID 9015
objektet.
Obs! Du har inte behörighet för datalager inte data reparation.
Kod ändras
Observera alltid testa koden korrigeringar i en kontrollerad miljö innan du installerar korrigeringar i dina produktionsdatorer. Importera alla SEPA-uppdateringar innan du tillämpar ändringen.
Lös problemet så här:
-
Ändra koden i egenskaper i formuläret Koppla kundtransaktioner (232) enligt följande:
Befintlig kod...OnModifyRecord=BEGIN
CODEUNIT.RUN(CODEUNIT::"Cust. Entry-Edit",Rec);
EXIT(FALSE);
END;
...Ersättningskod
...OnModifyRecord=BEGIN
CODEUNIT.RUN(CODEUNIT::"Cust. Entry-Edit",Rec);
IF "Applies-to ID" <> xRec."Applies-to ID" THEN
CalcApplnAmount;
EXIT(FALSE);
END;
... -
Ändra koden i funktionen HandlChosenEntries i formuläret Koppla kundtransaktioner (232) enligt följande:
Befintlig kod 1...IF NOT FromZeroGenJnl THEN
AppliedCustLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0);
IF AppliedCustLedgEntryTemp.FINDFIRST THEN BEGIN
AppliedCustLedgEntryTemp.CALCFIELDS("Remaining Amount");
IF Type = Type::Direct THEN
CalculateCurrency := ApplyingCustLedgEntry."Entry No." <> 0
ELSE
CalculateCurrency := TRUE;
IF (CurrencyCode <> AppliedCustLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN
AppliedCustLedgEntryTemp."Remaining Amount" :=
GenJnlPostLine.ExchAmount(
AppliedCustLedgEntryTemp."Remaining Amount",
AppliedCustLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible" :=
GenJnlPostLine.ExchAmount(
AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible",
AppliedCustLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
AppliedCustLedgEntryTemp."Amount to Apply" :=
GenJnlPostLine.ExchAmount(
AppliedCustLedgEntryTemp."Amount to Apply",
AppliedCustLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
END;
CASE Type OF
Type::Direct:
...Ersättningskod 1
...IF NOT FromZeroGenJnl THEN
AppliedCustLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0);
IF AppliedCustLedgEntryTemp.FINDFIRST THEN BEGIN
ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedCustLedgEntryTemp);
CASE Type OF
Type::Direct:
...Befintlig kod 2
...END ELSE BEGIN
AppliedCustLedgEntryTemp.SETRANGE(Positive);
AppliedCustLedgEntryTemp.FINDFIRST;
END;
IF (OldPmtDisc <> PmtDiscAmount) THEN
...Ersättningskod 2
...END ELSE BEGIN
AppliedCustLedgEntryTemp.SETRANGE(Positive);
AppliedCustLedgEntryTemp.FINDFIRST;
ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedCustLedgEntryTemp);
END;
IF (OldPmtDisc <> PmtDiscAmount) THEN
... -
Ändra koden i funktionen ExchangeAmountsOnLedgerEntry i formuläret Koppla kundtransaktioner (232) enligt följande:
Befintlig kod...CheckRounding;
END;
BEGIN
END.
}
...Ersättningskod
...CheckRounding;
END;
LOCAL PROCEDURE ExchangeAmountsOnLedgerEntry@20(Type@1003 : 'Direct,GenJnlLine,SalesHeader';CurrencyCode@1000 : Code[10];VAR AppliedCustLedgEntryTemp@1001 : Record 21);
VAR
CalculateCurrency@1002 : Boolean;
BEGIN
AppliedCustLedgEntryTemp.CALCFIELDS("Remaining Amount");
IF Type = Type::Direct THEN
CalculateCurrency := ApplyingCustLedgEntry."Entry No." <> 0
ELSE
CalculateCurrency := TRUE;
IF (CurrencyCode <> AppliedCustLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN
AppliedCustLedgEntryTemp."Remaining Amount" :=
GenJnlPostLine.ExchAmount(
AppliedCustLedgEntryTemp."Remaining Amount",
AppliedCustLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible" :=
GenJnlPostLine.ExchAmount(
AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible",
AppliedCustLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
AppliedCustLedgEntryTemp."Amount to Apply" :=
GenJnlPostLine.ExchAmount(
AppliedCustLedgEntryTemp."Amount to Apply",
AppliedCustLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
END;
END;
BEGIN
END.
}
... -
Ändra koden i egenskaper i formuläret Koppla leverantörstrans (233) enligt följande:
Befintlig kod...OnModifyRecord=BEGIN
CODEUNIT.RUN(CODEUNIT::"Vend. Entry-Edit",Rec);
EXIT(FALSE);
END;
...Ersättningskod
...OnModifyRecord=BEGIN
CODEUNIT.RUN(CODEUNIT::"Vend. Entry-Edit",Rec);
IF "Applies-to ID" <> xRec."Applies-to ID" THEN
CalcApplnAmount;
EXIT(FALSE);
END;
... -
Ändra koden i funktionen HandlChosenEntries i formuläret Koppla leverantörstrans (233) enligt följande:
Befintlig kod 1...IF NOT FromZeroGenJnl THEN
AppliedVendLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0);
IF AppliedVendLedgEntryTemp.FINDFIRST THEN BEGIN
AppliedVendLedgEntryTemp.CALCFIELDS("Remaining Amount");
IF Type = Type::Direct THEN
CalculateCurrency := ApplyingVendLedgEntry."Entry No." <> 0
ELSE
CalculateCurrency := TRUE;
IF (CurrencyCode <> AppliedVendLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN
AppliedVendLedgEntryTemp."Remaining Amount" :=
GenJnlPostLine.ExchAmount(
AppliedVendLedgEntryTemp."Remaining Amount",
AppliedVendLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible" :=
GenJnlPostLine.ExchAmount(
AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible",
AppliedVendLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
AppliedVendLedgEntryTemp."Amount to Apply" :=
GenJnlPostLine.ExchAmount(
AppliedVendLedgEntryTemp."Amount to Apply",
AppliedVendLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
END;
CASE Type OF
Type::Direct:
...Ersättningskod 1
...IF NOT FromZeroGenJnl THEN
AppliedVendLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0);
IF AppliedVendLedgEntryTemp.FINDFIRST THEN BEGIN
ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedVendLedgEntryTemp);
CASE Type OF
Type::Direct:
...Befintlig kod 2
...END ELSE BEGIN
AppliedVendLedgEntryTemp.SETRANGE(Positive);
AppliedVendLedgEntryTemp.FINDFIRST;
END;
IF (OldPmtdisc <> PmtDiscAmount) THEN
...Ersättningskod 2
...END ELSE BEGIN
AppliedVendLedgEntryTemp.SETRANGE(Positive);
AppliedVendLedgEntryTemp.FINDFIRST;
ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedVendLedgEntryTemp);
END;
IF (OldPmtdisc <> PmtDiscAmount) THEN
... -
Ändra koden i funktionen ExchangeAmountsOnLedgerEntry i formuläret Koppla leverantörstrans (233) enligt följande:
Befintlig kod...AppliesToID := AppliesToID2;
END;
BEGIN
END.
}
...Ersättningskod
...AppliesToID := AppliesToID2;
END;
PROCEDURE ExchangeAmountsOnLedgerEntry@14(Type@1000 : 'Direct,GenJnlLine,PurchHeader';CurrencyCode@1001 : Code[10];VAR AppliedVendLedgEntryTemp@1002 : Record 25);
VAR
CalculateCurrency@1003 : Boolean;
BEGIN
AppliedVendLedgEntryTemp.CALCFIELDS("Remaining Amount");
IF Type = Type::Direct THEN
CalculateCurrency := ApplyingVendLedgEntry."Entry No." <> 0
ELSE
CalculateCurrency := TRUE;
IF (CurrencyCode <> AppliedVendLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN
AppliedVendLedgEntryTemp."Remaining Amount" :=
GenJnlPostLine.ExchAmount(
AppliedVendLedgEntryTemp."Remaining Amount",
AppliedVendLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible" :=
GenJnlPostLine.ExchAmount(
AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible",
AppliedVendLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
AppliedVendLedgEntryTemp."Amount to Apply" :=
GenJnlPostLine.ExchAmount(
AppliedVendLedgEntryTemp."Amount to Apply",
AppliedVendLedgEntryTemp."Currency Code",
CurrencyCode,"Posting Date");
END;
END;
BEGIN
END.
}
...
Förutsättningar
Du måste ha någon av följande produkter som har installerat den här snabbkorrigeringen:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 SP1
Information om borttagning
Du kan inte ta bort den här snabbkorrigeringen.
Status
Microsoft har bekräftat att detta är ett problem i Microsoft-produkterna som nämns i avsnittet "Gäller".
Obs! Detta är en "SNABBPUBLICERING"-artikel skapad direkt från Microsoft support-organisationen. Informationen häri tillhandahålls i befintligt skick som svar på nya problem. Till följd av hastigheten för att göra det tillgängligt kan materialet innehålla typografiska fel och kan ändras när som helst utan föregående meddelande. Se Villkoren för användningför andra överväganden.