Príznaky
Základy a čiastky zoskupené nesprávne rovnaké percento DPH a obdobie 340 Vyhlásenie DPH hotovosti zapojených v španielskej verzii systému Microsoft Dynamics NAV 2009.zmeny kódu sekcia na riešenie tohto problému. Tento problém sa vyskytuje v nasledovných produktov:
Rovnaký scenár s normálne funguje podľa očakávania, oddelenie každej faktúry bez ohľadu na to, či majú rovnaké percento DPH. Postupujte podľa pokynov-
Španielskej verzii systému Microsoft Dynamics NAV 2009 R2
-
Španielskej verzii systému Microsoft Dynamics NAV 2009 SP1
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 skúšobný opravy v prostredí kontrolované pred použitím opravy výroby počítačov.
Ak chcete vyriešiť tento problém, postupujte nasledovne:-
Zmena kódu v správe urobiť vyhlásenie 340 (10743) takto:
Nahradenie kód 1... END;
END; // Delete the following line. OnAfterGetRecord=BEGIN // End of the deleted line. OperationCode := GetOperationCode(VATEntry2); VATBuffer."VAT %" := "VAT %"; ...Nahradenie kód 1
... END;
END; // Add the following lines. OnAfterGetRecord=VAR VendLedgEntryAppl@1100000 : Record 25; NewEntry@1100001 : Boolean; BEGIN // End of the added lines. OperationCode := GetOperationCode(VATEntry2); VATBuffer."VAT %" := "VAT %"; ...Existujúci kód 2
... VATBuffer.Amount := Amount;
END; VATBuffer.INSERT; // Delete the following lines. IF Type = VATEntry.Type::Purchase THEN BEGIN VATEntryTemporary := VATEntry2; VATEntryTemporary.INSERT; END; END; // End of the deleted lines. END; TotalFields=Base,Amount; ...Nahradenie kód 2
...VATBuffer.Amount := Amount;
END; VATBuffer.INSERT; // Add the following lines. END; IF Type = VATEntry.Type::Purchase THEN IF HasBeenRealized("Entry No.") OR ("Unrealized VAT Entry No." <> 0) THEN BEGIN NewEntry := CheckVLEApplication(VATEntry2); VATEntryTemporary.SETRANGE("Posting Date","Posting Date"); VATEntryTemporary.SETRANGE("Document No.","Document No."); VATEntryTemporary.SETRANGE("Document Type","Document Type"); VATEntryTemporary.SETRANGE(Type,Type); VATEntryTemporary.SETRANGE("VAT %","VAT %"); VATEntryTemporary.SETRANGE("Transaction No.","Transaction No."); IF VATEntryTemporary.FINDFIRST AND NOT NewEntry THEN BEGIN VATEntryTemporary.Base += Base; VATEntryTemporary.Amount += Amount; VATEntryTemporary.MODIFY; END ELSE BEGIN VATEntryTemporary := VATEntry2; VATEntryTemporary.INSERT; END; END ELSE BEGIN VATEntryTemporary := VATEntry2; VATEntryTemporary.INSERT; END; // End of the added lines. END; TotalFields=Base,Amount; ...Existujúci kód 3
... DataItemVarName=<Integer2>;
OnPreDataItem=BEGIN VATBuffer.FIND('-'); VATEntryTemporary.SETCURRENTKEY("VAT %","EC %"); IF VATEntryTemporary.FINDFIRST THEN; CurrReport.CREATETOTALS(VATBuffer2.Base,VATBuffer2.Amount); Fin := FALSE; ...Nahradenie kód 3
... DataItemVarName=<Integer2>;
OnPreDataItem=BEGIN VATBuffer.FIND('-'); // Delete the following line. VATEntryTemporary.SETCURRENTKEY("VAT %","EC %"); // End of the deleted line. IF VATEntryTemporary.FINDFIRST THEN; CurrReport.CREATETOTALS(VATBuffer2.Base,VATBuffer2.Amount); Fin := FALSE; ...Existujúci kód 4
...IF VATEntry.Type = VATEntry.Type::Purchase THEN BEGIN
VATEntryTemporary.Amount := VATBuffer.Amount; VATDeductAmt := CheckDeductibleVAT(VATEntryTemporary); // Delete the following lines. VATEntryTemporary.NEXT; RecordTypePurchase(VATEntry2); // End of the deleted lines. END; Fin := VATBuffer.NEXT = 0; END; ...Nahradenie kód 4
... IF VATEntry.Type = VATEntry.Type::Purchase THEN BEGIN
VATEntryTemporary.Amount := VATBuffer.Amount; VATDeductAmt := CheckDeductibleVAT(VATEntryTemporary); // Add the following lines. VATEntryTemporary.SETCURRENTKEY("VAT %","EC %"); VATEntryTemporary.SETRANGE("VAT %",VATBuffer."VAT %"); VATEntryTemporary.SETRANGE("EC %",VATBuffer."EC %"); VATEntryTemporary.FINDSET; REPEAT RecordTypePurchase(VATEntryTemporary); UNTIL VATEntryTemporary.NEXT = 0; // End of the added lines. END; Fin := VATBuffer.NEXT = 0; END; ... -
Zmena kódu v globálne premenné v správe urobiť vyhlásenie 340 (10743) takto:
Existujúci kód...VATEntryTemporary@1100078 : TEMPORARY Record 254;
TempDeclarationLines@1100149 : TEMPORARY Record 10744; TempVATEntry@1100007 : TEMPORARY Record 254; CommonDialogMgt@1100015 : Codeunit 412; OutFile@1100016 : File; DeclarationNum@1100017 : Text[4]; ...Nahradenie kódu
... VATEntryTemporary@1100078 : TEMPORARY Record 254;
TempDeclarationLines@1100149 : TEMPORARY Record 10744; TempVATEntry@1100007 : TEMPORARY Record 254; // Add the following line. TempDtldVendLedgerEntry@1100115 : TEMPORARY Record 380; // End of the added line. CommonDialogMgt@1100015 : Codeunit 412; OutFile@1100016 : File; DeclarationNum@1100017 : Text[4]; ... -
Zmena kódu v RecordTypePurchase funkcia v správe urobiť vyhlásenie 340 (10743) takto:
Existujúci kód... END ELSE
OperationDateText := FormatDate(VATEntryRec."Posting Date"); // Delete the following lines. IF VATEntryRec."Document Type" IN [VATEntryRec."Document Type"::Payment,VATEntryRec."Document Type"::Refund] THEN BEGIN UnrealizedVATEntryNo := VATEntryRec."Unrealized VAT Entry No."; DocumentDate := VATEntryRec."Posting Date"; IF UnrealizedVATEntryNo <> 0 THEN BEGIN UnrealizedVATEntry.GET(UnrealizedVATEntryNo); OperationDateText := FormatDate(UnrealizedVATEntry."Posting Date"); DocumentDate := UnrealizedVATEntry."Document Date"; // End of the deleted lines. END; END ELSE UnrealizedVATEntryNo := 0; ...Nahradenie kódu
... END ELSE
OperationDateText := FormatDate(VATEntryRec."Posting Date"); // Add the following lines. VATBuffer2.Base := VATBuffer.Base; VATBuffer2.Amount := VATBuffer.Amount; IF VATEntryRec."Document Type" IN [VATEntryRec."Document Type"::Payment,VATEntryRec."Document Type"::Refund] THEN BEGIN UnrealizedVATEntryNo := VATEntryTemporary."Unrealized VAT Entry No."; DocumentDate := VATEntryTemporary."Posting Date"; IF UnrealizedVATEntryNo <> 0 THEN BEGIN UnrealizedVATEntry.GET(UnrealizedVATEntryNo); OperationDateText := FormatDate(UnrealizedVATEntry."Posting Date"); DocumentDate := UnrealizedVATEntry."Document Date"; IF FindPmtOrderBillGrBankAcc(VATEntry.Type,VATEntry."Document No.") = '' THEN BEGIN VendorDocumentNo := UnrealizedVATEntry."External Document No."; VATBuffer2.Base := VATEntryTemporary.Base; VATBuffer2.Amount := VATEntryTemporary.Amount; END; // End of the added lines. END; END ELSE UnrealizedVATEntryNo := 0; ... -
Zmena kódu v CheckVLEApplication funkcia v správe urobiť vyhlásenie 340 (10743) takto:
Existujúci kód... PrevDeclarationNumEnable := ReplaceDeclaration;
END; BEGIN END. } ...Nahradenie kódu
...PrevDeclarationNumEnable := ReplaceDeclaration;
END; // Add the following lines. LOCAL PROCEDURE CheckVLEApplication@1100074(VATEntry@1100000 : Record 254) : Boolean; VAR VendorLedgerEntry@1100001 : Record 25; DtldVendLedgEntry@1100002 : Record 380; CheckVendLedgEntry@1100003 : Record 25; UnrealizedVendLedgEntry@1100004 : Integer; BEGIN FilterVendLedgerEntryByVATEntry(VendorLedgerEntry,VATEntry); UnrealizedVendLedgEntry := GetUnrealizedInvoiceVLENo(VATEntry."Unrealized VAT Entry No."); IF VendorLedgerEntry.FINDSET THEN REPEAT DtldVendLedgEntry.RESET; DtldVendLedgEntry.SETRANGE(Unapplied,FALSE); DtldVendLedgEntry.SETRANGE("Entry Type",DtldVendLedgEntry."Entry Type"::Application); DtldVendLedgEntry.SETRANGE("Applied Vend. Ledger Entry No.",VendorLedgerEntry."Entry No."); IF UnrealizedVendLedgEntry <> 0 THEN DtldVendLedgEntry.SETRANGE("Vendor Ledger Entry No.",UnrealizedVendLedgEntry); IF DtldVendLedgEntry.FINDSET THEN REPEAT IF (DtldVendLedgEntry."Vendor Ledger Entry No." <> DtldVendLedgEntry."Applied Vend. Ledger Entry No.") AND CheckVendLedgEntry.GET(DtldVendLedgEntry."Vendor Ledger Entry No.") THEN BEGIN IF ExistDtldVLE(DtldVendLedgEntry."Vendor Ledger Entry No.",DtldVendLedgEntry."Applied Vend. Ledger Entry No.") THEN EXIT(FALSE); InsertTempDtldVLE(DtldVendLedgEntry."Vendor Ledger Entry No.",DtldVendLedgEntry."Applied Vend. Ledger Entry No."); EXIT(TRUE); END; UNTIL DtldVendLedgEntry.NEXT = 0 ELSE BEGIN DtldVendLedgEntry.SETRANGE("Applied Vend. Ledger Entry No."); DtldVendLedgEntry.SETRANGE("Vendor Ledger Entry No.",VendorLedgerEntry."Entry No."); IF UnrealizedVendLedgEntry <> 0 THEN DtldVendLedgEntry.SETRANGE("Applied Vend. Ledger Entry No.",UnrealizedVendLedgEntry); IF DtldVendLedgEntry.FINDSET THEN REPEAT IF CheckVendLedgEntry.GET(DtldVendLedgEntry."Applied Vend. Ledger Entry No.") THEN BEGIN IF ExistDtldVLE(DtldVendLedgEntry."Applied Vend. Ledger Entry No.",DtldVendLedgEntry."Vendor Ledger Entry No.") THEN EXIT(FALSE); InsertTempDtldVLE(DtldVendLedgEntry."Applied Vend. Ledger Entry No.",DtldVendLedgEntry."Vendor Ledger Entry No."); EXIT(TRUE); END; UNTIL DtldVendLedgEntry.NEXT = 0; END; UNTIL VendorLedgerEntry.NEXT = 0; EXIT(TRUE); END; LOCAL PROCEDURE GetUnrealizedInvoiceVLENo@1100075(VATEntryNo@1100000 : Integer) : Integer; VAR VATEntry@1100002 : Record 254; VendLedgEntry@1100001 : Record 25; BEGIN IF NOT VATEntry.GET(VATEntryNo) THEN EXIT(0); FilterVendLedgerEntryByVATEntry(VendLedgEntry,VATEntry); IF VendLedgEntry.FINDFIRST THEN EXIT(VendLedgEntry."Entry No."); EXIT(0); END; LOCAL PROCEDURE FilterVendLedgerEntryByVATEntry@1100087(VAR VendLedgEntry@1100001 : Record 25;VATEntry@1100000 : Record 254); BEGIN VendLedgEntry.SETRANGE("Vendor No.",VATEntry."Bill-to/Pay-to No."); VendLedgEntry.SETRANGE("Posting Date",VATEntry."Posting Date"); VendLedgEntry.SETRANGE("Document Type",VATEntry."Document Type"); VendLedgEntry.SETRANGE("Document No.",VATEntry."Document No."); VendLedgEntry.SETRANGE("Transaction No.",VATEntry."Transaction No."); END; LOCAL PROCEDURE HasBeenRealized@1100064(VATEntryNo@1100000 : Integer) : Boolean; VAR UnrealizedVATEntry@1100001 : Record 254; BEGIN UnrealizedVATEntry.SETRANGE("Unrealized VAT Entry No.",VATEntryNo); EXIT(NOT UnrealizedVATEntry.ISEMPTY); END; LOCAL PROCEDURE ExistDtldVLE@1100195(VLENo@1100001 : Integer;AppliedVLENo@1100000 : Integer) : Boolean; BEGIN TempDtldVendLedgerEntry.SETRANGE("Vendor Ledger Entry No.",VLENo); TempDtldVendLedgerEntry.SETRANGE("Applied Vend. Ledger Entry No.",AppliedVLENo); EXIT(NOT TempDtldVendLedgerEntry.ISEMPTY); END; LOCAL PROCEDURE InsertTempDtldVLE@1100191(VLENo@1100000 : Integer;AppliedVLENo@1100001 : Integer); BEGIN TempDtldVendLedgerEntry.INIT; IF TempDtldVendLedgerEntry.FINDLAST THEN; TempDtldVendLedgerEntry."Entry No." += 1; TempDtldVendLedgerEntry."Vendor Ledger Entry No." := VLENo; TempDtldVendLedgerEntry."Applied Vend. Ledger Entry No." := AppliedVLENo; TempDtldVendLedgerEntry.INSERT; 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:
-
Španielskej verzii systému Microsoft Dynamics NAV 2009 R2
-
Španielskej verzii systému 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ť revidované kedykoľvek bez predchádzajúceho upozornenia. Prečítajte si Podmienky používaniaz iných dôvodov.