Kui pärast makse hinnaalandi müügi või ostu dokumendid Belgia versioonis Microsoft Dynamics nav-i 2009 "algse makse hinnaalandi. Võimalikud"väärtus on vale. See probleem ilmneb, kui "Kohanda makse hinnaalandi" suvand on sisse lülitatud. See probleem ilmneb järgmiste toodetega:
-
Microsoft Dynamics nav-i 2009 R2 Belgia versioon
-
Belgia versioonis Microsoft Dynamics nav-i 2009 Service Pack 1 (SP1)
Lahendus
Kiirparanduse teave
Lasknud välja toetatava käigultparanduse on nüüd Microsoftilt saadaval. Kuid see on ette nähtud ainult selles artiklis kirjeldatud probleemi kõrvaldamiseks. Rakendage seda ainult süsteemides, kus ilmneb see konkreetne probleem. Seda käigultparandust võidakse täiendavalt testida. Seega, kui probleem teie tööd tõsiselt ei kahjusta, soovitame oodata järgmist hoolduspaketti Microsoft Dynamics nav-i 2009 või järgmise Microsoft Dynamics nav-i versiooni, mis sisaldab seda kiirparandust.
Märkus. Erijuhtudel kulud, mis tekivad teatud palub tühistada saab kui tehniline toetus Professional Microsoft Dynamics ja nendega seotud toodete leiab, et mõni konkreetne värskendus lahendab teie probleemi. Tavaline tugiteenuste kohaldatakse täiendavat tugiteenust vajavatele küsimustele ning probleemidele, mis pole lahendatavad konkreetse värskenduse installimisega.
Installiteave
Microsoft pakub programmeerimisnäiteid ainult artikli illustreerimiseks ilma igasuguse otsese või kaudse garantiita. See hõlmab, kuid ei piirdu kaudseid garantiisid turustatavuse või kindlaks otstarbeks sobivusega. See artikkel eeldab, et olete demonstreeritava programmeerimiskeelega programmeerimise keel ning luua protseduuride ja silumiseks kasutatavate tööriistadega tuttav. Microsofti tugitehnikud võivad aidata mõne konkreetse protseduuri talitlust selgitada. Siiski ei muuda nad neid näiteid lisafunktsioonide pakkumiseks ega Koosta vastavaid protseduure teie konkreetsetele nõuetele.
Märkus. Enne selle kiirparanduse installimist veenduge, et kõik Microsoft Dynamics nav-i kliendi kasutajat sisse loginud süsteem välja. See hõlmab Microsoft Dynamics nav-i rakenduste Server (NAS) teenuseid. Peaks olema ainult kliendi kasutaja on sisse logitud, kui otsustate seda käigultparandust.
Selle kiirparanduse rakendamiseks peab teil olema arendaja litsentsi.
Soovitame Windowsi sisselogimise aken või aken andmebaasi logimine kasutajakonto määrata "SUPER" rolli ID. Kui "SUPER" rolli ID-d ei saa määratud kasutajakonto, peate veenduma, et kasutaja konto on järgmised õigused:
-
Sa muutuvad objekti Muuda õigusi.
-
Käivita luba süsteemi objekti ID 5210 objekti ja süsteemi objekti ID 9015
objekti.
Märkus. Teil pole õigust andmeid talletab enne, kui olete andmete parandamiseks.
Koodi muudatusi
Märkus. Alati test koodi lahendab kontrollitavas keskkonnas enne rakendamist tootmine arvutite parandused.
Selle probleemi lahendamiseks toimige järgmiselt.
-
Muuta koodi DivideAmount funktsiooni koodiplokk 80 järgmiselt:
Kood 1...END;
LOCAL PROCEDURE DivideAmount@8(QtyType@1000 : 'General,Invoicing,Shipping';SalesLineQty@1001 : Decimal);
BEGIN
IF RoundingLineInserted AND (RoundingLineNo = SalesLine."Line No.") THEN
EXIT;
...Kood 1
...END;
LOCAL PROCEDURE DivideAmount@8(QtyType@1000 : 'General,Invoicing,Shipping';SalesLineQty@1001 : Decimal);
VAR
PmtDiscountBase@1010000 : Decimal;
BEGIN
IF RoundingLineInserted AND (RoundingLineNo = SalesLine."Line No.") THEN
EXIT;
...Kood 2
...END;
END;
IF TempVATAmountLine."Line Amount" - TempVATAmountLine."Invoice Discount Amount" <> 0 THEN BEGIN
TempVATAmountLineRemainder."Pmt. Discount Amount" :=
TempVATAmountLineRemainder."Pmt. Discount Amount" +
TempVATAmountLine."VAT Base" * SalesHeader."Payment Discount %" / 100 *
("Line Amount" - "Inv. Discount Amount") /
(TempVATAmountLine."Line Amount" - TempVATAmountLine."Invoice Discount Amount");
"Pmt. Discount Amount" :=
...Asendamine kood 2
...END;
END;
IF TempVATAmountLine."Line Amount" - TempVATAmountLine."Invoice Discount Amount" <> 0 THEN BEGIN
IF GLSetup."Adjust for Payment Disc." THEN
PmtDiscountBase := TempVATAmountLine."Amount Including VAT"
ELSE
PmtDiscountBase := TempVATAmountLine."VAT Base";
TempVATAmountLineRemainder."Pmt. Discount Amount" :=
TempVATAmountLineRemainder."Pmt. Discount Amount" +
PmtDiscountBase * SalesHeader."Payment Discount %" / 100 *
("Line Amount" - "Inv. Discount Amount") /
(TempVATAmountLine."Line Amount" - TempVATAmountLine."Invoice Discount Amount");
"Pmt. Discount Amount" :=
... -
Muuta koodi InvoiceRounding funktsiooni koodiplokk 80 järgmiselt:
Kood...(1 + (1 - SalesHeader."VAT Base Discount %" / 100) * "VAT %" / 100),
Currency."Amount Rounding Precision"));
VALIDATE("Amount Including VAT",InvoiceRoundingAmount);
"Line No." := NextLineNo;
IF NOT UseTempData THEN BEGIN
DocDim2.SETRANGE("Table ID",DATABASE::"Sales Line");
...Eemaldamise teave
...(1 + (1 - SalesHeader."VAT Base Discount %" / 100) * "VAT %" / 100),
Currency."Amount Rounding Precision"));
VALIDATE("Amount Including VAT",InvoiceRoundingAmount);
VALIDATE("Pmt. Discount Amount",
ROUND(InvoiceRoundingAmount * SalesHeader."Payment Discount %" / 100,Currency."Amount Rounding Precision"));
"Line No." := NextLineNo;
IF NOT UseTempData THEN BEGIN
DocDim2.SETRANGE("Table ID",DATABASE::"Sales Line");
... -
Muuta koodi DivideAmount funktsiooni koodiplokk 90 järgmiselt:
Kood 1...END;
LOCAL PROCEDURE DivideAmount@8(QtyType@1000 : 'General,Invoicing,Shipping';PurchLineQty@1001 : Decimal);
BEGIN
IF RoundingLineInserted AND (RoundingLineNo = PurchLine."Line No.") THEN
EXIT;
...Kood 1
...END;
LOCAL PROCEDURE DivideAmount@8(QtyType@1000 : 'General,Invoicing,Shipping';PurchLineQty@1001 : Decimal);
VAR
PmtDiscountBase@1010000 : Decimal;
BEGIN
IF RoundingLineInserted AND (RoundingLineNo = PurchLine."Line No.") THEN
EXIT;
...Kood 2
...END;
END;
IF TempVATAmountLine."Line Amount" - TempVATAmountLine."Invoice Discount Amount" <> 0 THEN BEGIN
TempVATAmountLineRemainder."Pmt. Discount Amount" :=
TempVATAmountLineRemainder."Pmt. Discount Amount" +
TempVATAmountLine."VAT Base" * PurchHeader."Payment Discount %" / 100 *
("Line Amount" - "Inv. Discount Amount") /
(TempVATAmountLine."Line Amount" - TempVATAmountLine."Invoice Discount Amount");
"Pmt. Discount Amount" :=
...Asendamine kood 2
...END;
END;
IF TempVATAmountLine."Line Amount" - TempVATAmountLine."Invoice Discount Amount" <> 0 THEN BEGIN
IF GLSetup."Adjust for Payment Disc." THEN
PmtDiscountBase := TempVATAmountLine."Amount Including VAT"
ELSE
PmtDiscountBase := TempVATAmountLine."VAT Base";
TempVATAmountLineRemainder."Pmt. Discount Amount" :=
TempVATAmountLineRemainder."Pmt. Discount Amount" +
PmtDiscountBase * PurchHeader."Payment Discount %" / 100 *
("Line Amount" - "Inv. Discount Amount") /
(TempVATAmountLine."Line Amount" - TempVATAmountLine."Invoice Discount Amount");
"Pmt. Discount Amount" :=
... -
Muuta koodi InvoiceRounding funktsiooni koodiplokk 90 järgmiselt:
Kood...(1 + (1 - PurchHeader."VAT Base Discount %" / 100) * "VAT %" / 100),
Currency."Amount Rounding Precision"));
VALIDATE("Amount Including VAT",InvoiceRoundingAmount);
"Line No." := NextLineNo;
IF NOT UseTempData THEN BEGIN
DocDim2.SETRANGE("Table ID",DATABASE::"Purchase Line");
...Eemaldamise teave
...(1 + (1 - PurchHeader."VAT Base Discount %" / 100) * "VAT %" / 100),
Currency."Amount Rounding Precision"));
VALIDATE("Amount Including VAT",InvoiceRoundingAmount);
VALIDATE("Pmt. Discount Amount",
ROUND(InvoiceRoundingAmount * PurchHeader."Payment Discount %" / 100,Currency."Amount Rounding Precision"));
"Line No." := NextLineNo;
IF NOT UseTempData THEN BEGIN
DocDim2.SETRANGE("Table ID",DATABASE::"Purchase Line");
...
Eeltingimused
Teil peab olema üks selle kiirparanduse installinud järgmisi tooteid:
-
Microsoft Dynamics nav-i 2009 R2 Belgia versioon
-
Belgia versioonis Microsoft Dynamics nav-i 2009 SP1
Eemaldamise teave
See käigultparandus ei saa eemaldada.
Olek
Microsoft on kinnitanud, et see probleem esineb jaotises "Kehtib järgmiste toodete kohta" loetletud Microsofti toodetel.
Märkus. See on "Kiire avaldamise" artikli loonud otse Microsofti tugiteenuse pakkujalt. Siintoodud teave on esitatud lähtudes-olemasoleval kujul vastusena ilmnenud probleemidele. Kiire avaldamise materjalides esineda trükivigu ja võidakse muuta ette teatamata. Vt Kasutustingimusedmuid kaalutlusi.