Pri účtovaní faktúra a normálne denník alebo opakovaný, ktorý obsahuje odpočítať daň z pridanej hodnoty (DPH), DPH Portugalská verzia Microsoft Dynamics NAV 2009, zobrazí nasledujúce chybové hlásenie:
"Transakcia nemôže dokončiť, pretože spôsobí nekonzistencie v tabuľke Finančná položka. Skontrolujte, kde a ako konzistentné funkcia slúži transakcia zistiť príčinu chyby. Obráťte sa na správcu systému. Tabuľky môžete označiť ako nekonzistentné počas komplexnej úlohy, ako napríklad vysielania. To bráni údaje aktualizujú nesprávne."
Postupujte podľa pokynov zmeny kódu sekcia na riešenie tohto problému. Tento problém sa vyskytuje v nasledujúcich produktov:
-
Portugalská verzia Microsoft Dynamics NAV 2009 R2
-
Portugalská verzia Microsoft Dynamics NAV 2009 SP1
Je špecifické a % DPH D..
Napríklad:
1, 15 0, 25 = 0,002875 a zaoblené na 2 desatinné miesta je 0.
Procedúra 12 je obmedzenie iba po čiastky <> 0, aby sa vynechané položky daň z pridanej hodnoty (DPH).
Riešenie
Informácie o rýchlej oprave
Rýchla oprava je k dispozícii od spoločnosti Microsoft. Je však určená iba opraviť problém popísaný v tomto článku. Použite ju iba v počítačoch s týmto konkrétnym problémom. Môže, že táto rýchla oprava bude ďalej testovaná. Ak vám nespôsobuje tento problém, odporúčame vám počkať na ďalšiu Microsoft Dynamics NAV 2009 service pack alebo ďalšej verzii Microsoft Dynamics NAV, ktorá obsahuje túto rýchlu opravu.
Poznámka: V špeciálnych prípadoch sa poplatky, ktoré sú telefonickú podporu nemusia účtovať ak technickú podporu Professional pre Microsoft Dynamics a súvisiace produkty zistí, že táto konkrétna aktualizácia vyrieši váš problém. Ďalšie otázky a žiadosti o technickú podporu, ktoré sa netýkajú tejto špecifickej aktualizácie, podliehajú bežným sadzbám za poskytovanie technickej podpory.
Informácie o inštalácii
Spoločnosť Microsoft poskytuje príklady programovacieho kódu len ako názornú ukážku bez vyjadrených či predpokladaných záruk. Tie okrem iného zahŕňajú predpokladané záruky obchodovateľnosti alebo vhodnosti na konkrétny účel. Tento článok predpokladá, že ovládate predvádzaný programovací jazyk a nástroje, ktoré sa používajú na vytváranie a ladenie procedúr. Pracovníci technickej podpory spoločnosti Microsoft môžu vysvetliť fungovanie konkrétneho postupu. Ale nemôžu tieto príklady poskytovať pridanú funkčnosť alebo konštrukčné procedúry zohľadňujúce vaše konkrétne požiadavky.
Poznámka: Pred inštaláciou tejto rýchlej opravy, kontrola všetkých používateľov klienta Microsoft Dynamics NAV systém. To zahŕňa služby Microsoft Dynamics NAV aplikácie servera (NAS). Mali by ste byť iba klient prihláseného používateľa je pri implementácii túto rýchlu opravu.
Vykonávať túto rýchlu opravu, musíte mať licencie pre vývojárov.
Odporúčame, aby používateľského konta v okne prihlásenia systému Windows alebo v okne prihlásenia do databázy pridelí "SUPER" úlohu ID. Ak používateľské konto nemožno priradiť úlohu ID "SUPER", musíte overiť, že používateľské konto má nasledujúce povolenia:
-
Zmeniť povolenia pre objekt, ktorý sa zmení.
-
Povolenia na vykonanie systému objekt ID 5210 a systém objekt ID 9015
objekt.
Poznámka: Nemusíte mať práva ukladá údaje, pokiaľ budete musieť vykonať opravy údajov.
Zmeny kódu
Poznámka: vždy test kód opravy v prostredí kontrolované pred použitím opravy výroby počítače. Pred použitím zmeny, importujte všetky aktualizácie SEPA.
Ak chcete vyriešiť tento problém, postupujte nasledovne:
-
Zmena kódu v InsertVAT funkcia v Gen. denníkov.-Post riadok procedúra (12) takto:
Nahradenie kód 1...VATDifferenceLCY@1013 : Decimal;
SrcCurrVATDifference@1014 : Decimal;
BEGIN
WITH GenJnlLine DO BEGIN
...Nahradenie kód 1
...VATDifferenceLCY@1013 : Decimal;
SrcCurrVATDifference@1014 : Decimal;
// Add the following line.
VATAmountTotal@1015 : Decimal;
// End of the added line.
BEGIN
WITH GenJnlLine DO BEGIN
...Existujúci kód 2
...GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);
InsertGLEntry(TRUE);
// Delete the following lines.
VATPostingSetup.TESTFIELD("Return VAT account (Sales)");
InitGLEntry(
VATPostingSetup."Return VAT account (Sales)",
// -GLEntryVATAmount - VATBase * VATPostingSetup."VAT N.D. %" / 100,
-TempVATAmount,
// -SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100,
ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),
TRUE,TRUE);
InsertGLEntry(TRUE);
// End of the deleted lines.
END
ELSE
...Nahradenie kód 2
...GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);
InsertGLEntry(TRUE);
END
ELSE
...Existujúci kód 3
...END
ELSE
// Delete the following lines.
BEGIN
IF NOT GenJnlLine."UE Aquisition Not Accep." THEN BEGIN
VATPostingSetup.TESTFIELD("Purchase VAT Account");
InitGLEntry(
VATPostingSetup."Purchase VAT Account",
GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);
InsertGLEntry(TRUE);
END;
//--------
VATPostingSetup.TESTFIELD("Reverse Chrg. VAT Acc.");
InitGLEntry(
VATPostingSetup."Reverse Chrg. VAT Acc.",
// -GLEntryVATAmount - VATBase * VATPostingSetup."VAT N.D. %" / 100,
// ROUND(-GLEntryVATAmount - VATBase * VATPostingSetup."VAT N.D. %" / 100),
ROUND((- VATBase * VATPostingSetup."VAT D. %" / 100) - (VATBase * VATPostingSetup."VAT N.D. %" / 100)),
// -SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100,
ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),
TRUE,TRUE);
// End of the deleted lines.
InsertGLEntry(TRUE);
END;
...Nahradenie kód 3
...END
ELSE
// Add the following lines.
IF NOT GenJnlLine."UE Aquisition Not Accep." THEN BEGIN
VATPostingSetup.TESTFIELD("Purchase VAT Account");
InitGLEntry(
VATPostingSetup."Purchase VAT Account",
GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);
// End of the added lines.
InsertGLEntry(TRUE);
END;
...Existujúci kód 4
...END;
END;
END;
END;
...Nahradenie kód 4
... END;
END;
// Add the following lines.
IF IsPurchaseReverseChargeVAT(UnrealizedVAT) THEN
IF "Document Type"= "Document Type"::"Credit Memo" THEN BEGIN
IF (NOT GenJnlLine."UE Aquisition Not Accep.") AND (TempVATAmount <> 0) THEN BEGIN
VATPostingSetup.TESTFIELD("Return VAT account (Sales)");
InitGLEntry(
VATPostingSetup."Return VAT account (Sales)",
-TempVATAmount,
ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),
TRUE,TRUE);
InsertGLEntry(TRUE);
END;
END ELSE BEGIN
VATAmountTotal
:= ROUND((- VATBase * VATPostingSetup."VAT D. %" / 100) - (VATBase * VATPostingSetup."VAT N.D. %" / 100));
IF VATAmountTotal <> 0 THEN BEGIN
VATPostingSetup.TESTFIELD("Reverse Chrg. VAT Acc.");
InitGLEntry(
VATPostingSetup."Reverse Chrg. VAT Acc.",VATAmountTotal,
ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),
TRUE,TRUE);
InsertGLEntry(TRUE);
END;
END;
// End of the added lines.
END;
END;
... -
Zmena kódu v IsPurchaseReverseChargeVAT funkcia v Gen. denníkov.-Post riadok procedúra (12) takto:
Existujúci kód...END;
BEGIN
END.
...Nahradenie kódu
...END;
// Add the following lines.
LOCAL PROCEDURE IsPurchaseReverseChargeVAT@1110015(UnrealizedVAT@1110000 : Boolean) : Boolean;
BEGIN
EXIT(
(GenJnlLine."Gen. Posting Type" = GenJnlLine."Gen. Posting Type"::Purchase) AND (NOT UnrealizedVAT) AND
(VATPostingSetup."VAT Calculation Type" = VATPostingSetup."VAT Calculation Type"::"Reverse Charge VAT" ));
END;
// End of the added lines.
BEGIN
END.
...
Požiadavky
Musíte mať jednu z nasledovných produktov nainštalovaný chcete použiť túto rýchlu opravu:
-
Portugalská verzia Microsoft Dynamics NAV 2009 R2
-
Portugalská verzia Microsoft Dynamics NAV 2009 SP1
Informácie o odstránení
Nemôžete odstrániť túto rýchlu opravu.
Stav
Spoločnosť Microsoft potvrdila, že ide o problém v produktoch spoločnosti Microsoft, ktoré sú uvedené v časti Vzťahuje sa na.
Poznámka: To je "Rýchlo publikovať" článok vytvorené priamo v rámci organizácie technickej podpory spoločnosti Microsoft. Uvedené informácie sa poskytuje ako-v reakcii na naliehavé problémy. Rýchlosťou robiť materiály môžu obsahovať typografické chyby a môžu byť kedykoľvek bez predchádzajúceho upozornenia. Prečítajte si Podmienky používaniaz iných dôvodov.