Prihláste sa s kontom Microsoft
Prihláste sa alebo si vytvorte konto.
Dobrý deň,
Vyberte iné konto.
Máte viacero kont
Vyberte konto, s ktorým sa chcete prihlásiť.

Príznaky

Pri vytváraní opravnej faktúry poľa ceny inc. DPH zmenil, jednotka cena sú nesprávne maďarský verzia systému Microsoft Dynamics NAV 2009 R2. Postupujte podľa pokynov zmeny kódu sekcia na vyriešenie tohto problému. Tento problém sa vyskytuje v nasledovných produktov:

  • Maďarský verzia systému Microsoft Dynamics NAV 2009 R2

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:

  1. Zmena kódu v UpdateVATAmounts funkcia v tabuľke Riadok predaja opravy (14536):
    Existujúci kód

    ...Amount * (1 - SalesHeader."VAT Base Discount %" / 100),
    Currency."Amount Rounding Precision");
    "Amount Including VAT" :=
    ROUND(
    Amount * (1 - SalesHeader."VAT Base Discount %" / 100) * "VAT %" / 100,
    Currency."Amount Rounding Precision",Currency.VATRoundingDirection);
    END;
    "VAT Calculation Type"::"Full VAT":
    BEGIN
    ...

    Nahradenie kódu

    ...Amount * (1 - SalesHeader."VAT Base Discount %" / 100),
    Currency."Amount Rounding Precision");
    "Amount Including VAT" :=

    // Add the following line.
    Amount +
    // End of the added line.

    ROUND(
    Amount * (1 - SalesHeader."VAT Base Discount %" / 100) * "VAT %" / 100,
    Currency."Amount Rounding Precision",Currency.VATRoundingDirection);
    END;
    "VAT Calculation Type"::"Full VAT":
    BEGIN
    ...
  2. Zmena kódu v CheckLineAmount funkcia v tabuľke Riadok predaja opravy (14536):
    Nahradenie kód 1

    ..."Unit Price Incl. Discount" := "Unit Price" - "Unit Price" * "Line Discount %" / 100;
    END;

    // Delete the following line.
    PROCEDURE CheckLineAmount@1360000();
    // End of the deleted line.

    BEGIN
    // PS16433.begin
    IF "Before/ After correction" = "Before/ After correction"::After THEN BEGIN
    ...

    Nahradenie kód 1

    ..."Unit Price Incl. Discount" := "Unit Price" - "Unit Price" * "Line Discount %" / 100;
    END;

    // Add the following lines.
    PROCEDURE CheckLineAmount@1170219();
    VAR
    SalesinvHeader@1170001 : Record 112;
    // End of the added lines.

    BEGIN
    // PS16433.begin
    IF "Before/ After correction" = "Before/ After correction"::After THEN BEGIN
    ...

    Existujúci kód 2

    ...// PS16433.begin
    IF "Before/ After correction" = "Before/ After correction"::After THEN BEGIN
    SalesCorrLine.GET("Document Type","Document No.","Correction Line No.","Before/ After correction"::Before);
    GetCorrType;
    IF (SalesCorrLine."Line Amount" > "Line Amount") AND
    ("Document Type" = "Document Type"::Invoice) AND
    (SalesCorrectionType."Correction Type" = SalesCorrectionType."Correction Type"::"Quantity and Value")
    THEN
    ...

    Nahradenie kód 2

    ... // PS16433.begin
    IF "Before/ After correction" = "Before/ After correction"::After THEN BEGIN
    SalesCorrLine.GET("Document Type","Document No.","Correction Line No.","Before/ After correction"::Before);

    // Add the following line.
    SalesinvHeader.GET(SalesHeader."Corr. Document No.");
    // End of the added line.

    GetCorrType;
    IF (SalesCorrLine."Line Amount" > "Line Amount") AND

    // Add the following line.
    (SalesHeader."Prices Including VAT" = SalesinvHeader."Prices Including VAT") AND
    // End of the added line.

    ("Document Type" = "Document Type"::Invoice) AND
    (SalesCorrectionType."Correction Type" = SalesCorrectionType."Correction Type"::"Quantity and Value")
    THEN
    ...
  3. Zmena kódu v údaje položky číslo 5 v - faktúry (HU) správa (14516):
    Existujúci kód

    ...DataItemTable=Table14537;
    DataItemTableView=SORTING(Document No.,Correction Line No.,Before/ After correction,Document Type)
    WHERE(Before/ After correction=FILTER(Before),
    Document Type=CONST(Posted Invoice));
    DataItemVarName=PostedSalesCorrLineBefore;
    DataItemLinkReference=Sales Invoice Header;
    DataItemLink=Document No.=FIELD(No.);
    }
    SECTIONS
    {
    ...

    Nahradenie kódu

    ...DataItemTable=Table14537;
    DataItemTableView=SORTING(Document No.,Correction Line No.,Before/ After correction,Document Type)
    WHERE(Before/ After correction=FILTER(Before),
    Document Type=CONST(Posted Invoice));
    DataItemVarName=PostedSalesCorrLineBefore;

    // Add the following lines.
    OnAfterGetRecord=BEGIN
    IF SalesInvHeader.GET("Sales Invoice Header"."Corr. Document No.") THEN
    IF SalesInvHeader."Prices Including VAT" <> "Sales Invoice Header"."Prices Including VAT" THEN
    "Unit Price Incl. Discount" := "VAT Base Amount" / Quantity;
    END;

    // End of the added lines.

    DataItemLinkReference=Sales Invoice Header;
    DataItemLink=Document No.=FIELD(No.);
    }
    SECTIONS
    {
    ...
  4. Zmena kódu v údaje položky číslo 6 predaj - faktúry (HU) správa (14516):
    Existujúci kód

    ...DataItemTable=Table14537;
    DataItemTableView=SORTING(Document No.,Correction Line No.,Before/ After correction,Document Type)
    WHERE(Before/ After correction=FILTER(After),
    Document Type=CONST(Posted Invoice));
    DataItemVarName=PostedSalesCorrLineAfter;
    DataItemLinkReference=PostedSalesCorrLineBefore;
    DataItemLink=Document No.=FIELD(Document No.),
    Correction Line No.=FIELD(Correction Line No.);
    }
    SECTIONS
    ...

    Nahradenie kódu

    ...DataItemTable=Table14537;
    DataItemTableView=SORTING(Document No.,Correction Line No.,Before/ After correction,Document Type)
    WHERE(Before/ After correction=FILTER(After),
    Document Type=CONST(Posted Invoice));
    DataItemVarName=PostedSalesCorrLineAfter;

    // Add the following lines.
    OnAfterGetRecord=BEGIN
    IF SalesInvHeader."Prices Including VAT" <> "Sales Invoice Header"."Prices Including VAT" THEN
    "Unit Price Incl. Discount" := "VAT Base Amount" / Quantity;
    END;

    // End of the added lines.

    DataItemLinkReference=PostedSalesCorrLineBefore;
    DataItemLink=Document No.=FIELD(Document No.),
    Correction Line No.=FIELD(Correction Line No.);
    }
    SECTIONS
    ...
  5. Zmena kódu v globálne premenné v - faktúry (HU) správa (14516):
    Existujúci kód

    ...VALExchRate@1360016 : Text[50];
    Text14530@1360017 : TextConst 'ENU=%1/%2;HUN=%1/%2';
    GroupVATText@13600018 : Text[30];
    CorrInvText@1360018 : TextConst 'ENU=C O R R E C T I V E I N V O I C E;HUN=H E L Y E S B Ö T Š S Z µ M L A';
    LogInteractionEnable@19003940 : Boolean INDATASET;

    PROCEDURE InitLogInteraction@1360000();
    BEGIN
    LogInteraction := SegManagement.FindInteractTmplCode(4) <> '';
    END;
    ...

    Nahradenie kódu

    ...VALExchRate@1360016 : Text[50];
    Text14530@1360017 : TextConst 'ENU=%1/%2;HUN=%1/%2';
    GroupVATText@13600018 : Text[30];
    CorrInvText@1360018 : TextConst 'ENU=C O R R E C T I V E I N V O I C E;HUN=H E L Y E S B Ö T Š S Z µ M L A';
    LogInteractionEnable@19003940 : Boolean INDATASET;

    // Add the following line.
    SalesInvHeader@13600019 : Record 112;
    // End of the added line.

    PROCEDURE InitLogInteraction@1360000();
    BEGIN
    LogInteraction := SegManagement.FindInteractTmplCode(4) <> '';
    END;
    ...
  6. Zmena kódu v InitSalesLineOnCharge funkcia v VATCorrectionManagement procedúra (14535):
    Nahradenie kód 1

    ...SalesLine.INSERT;
    CopyDim(SalesLine,SalesCorrLine);
    END;

    PROCEDURE InitSalesLineOnCharge@1360001(VAR SalesLine@1360000 : Record 37;SalesCorrLine@1360001 : Record 14536;QtyOnSalesLine@1360002 : Decimal);
    BEGIN
    InitSalesLine(SalesCorrLine,SalesLine);
    SalesLine.Type := SalesLine.Type::"Charge (Item)";
    SalesLine."No." := SalesCorrType."Item Charge Code";
    SalesLine.VALIDATE("Unit of Measure Code",'');
    ...

    Nahradenie kód 1

    ...SalesLine.INSERT;
    CopyDim(SalesLine,SalesCorrLine);
    END;

    PROCEDURE InitSalesLineOnCharge@1360001(VAR SalesLine@1360000 : Record 37;SalesCorrLine@1360001 : Record 14536;QtyOnSalesLine@1360002 : Decimal);

    // Add the following lines.
    VAR
    SalesInvHeader@1360003 : Record 112;
    // End of the added lines.

    BEGIN
    InitSalesLine(SalesCorrLine,SalesLine);
    SalesLine.Type := SalesLine.Type::"Charge (Item)";
    SalesLine."No." := SalesCorrType."Item Charge Code";
    SalesLine.VALIDATE("Unit of Measure Code",'');
    ...

    Existujúci kód 2

    ...InitSalesLine(SalesCorrLine,SalesLine);
    SalesLine.Type := SalesLine.Type::"Charge (Item)";
    SalesLine."No." := SalesCorrType."Item Charge Code";
    SalesLine.VALIDATE("Unit of Measure Code",'');
    SalesLine.VALIDATE(Quantity,QtyOnSalesLine);
    SalesLine.VALIDATE("Unit Price",SalesCorrLine."Unit Price");
    IF SalesLine.Quantity <> 0 THEN
    SalesLine.VALIDATE("Line Discount %",SalesCorrLine."Line Discount %");
    SalesLine.UpdateAmounts;
    SalesLine.VALIDATE("Unit Cost (LCY)",0);
    ...

    Nahradenie kód 2

    ...InitSalesLine(SalesCorrLine,SalesLine);
    SalesLine.Type := SalesLine.Type::"Charge (Item)";
    SalesLine."No." := SalesCorrType."Item Charge Code";
    SalesLine.VALIDATE("Unit of Measure Code",'');
    SalesLine.VALIDATE(Quantity,QtyOnSalesLine);

    // Add the following lines.
    IF (SalesCorrLine."Before/ After correction" = SalesCorrLine."Before/ After correction"::Before) AND
    (SalesInvHeader.GET(SalesCorrLine."Source Document No.")) AND
    (SalesHeader."Prices Including VAT" <> SalesInvHeader."Prices Including VAT")
    THEN BEGIN
    IF SalesHeader."Prices Including VAT" THEN
    SalesLine.VALIDATE("Unit Price",SalesCorrLine."Amount Including VAT" / SalesCorrLine.Quantity)
    ELSE
    SalesLine.VALIDATE("Unit Price",SalesCorrLine."VAT Base Amount" / SalesCorrLine.Quantity);
    END ELSE
    // End of the added lines.

    SalesLine.VALIDATE("Unit Price",SalesCorrLine."Unit Price");
    IF SalesLine.Quantity <> 0 THEN
    SalesLine.VALIDATE("Line Discount %",SalesCorrLine."Line Discount %");
    SalesLine.UpdateAmounts;
    SalesLine.VALIDATE("Unit Cost (LCY)",0);
    ...


Požiadavky

Musíte mať jednu z nasledovných produktov nainštalovaný chcete použiť túto rýchlu opravu:

  • Maďarský verzia systému Microsoft Dynamics NAV 2009 R2

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.

Potrebujete ďalšiu pomoc?

Chcete ďalšie možnosti?

Môžete preskúmať výhody predplatného, prehľadávať školiace kurzy, naučiť sa zabezpečiť svoje zariadenie a ešte oveľa viac.

Komunity pomôžu s kladením otázok a odpovedaním na ne, s poskytovaním pripomienok a so získavaním informácií od odborníkov s bohatými znalosťami.

Boli tieto informácie užitočné?

Aká je podľa vás jazyková kvalita textu?
Čo sa vám páčilo, prípadne čo nie?
Stlačením tlačidla Odoslať sa vaše pripomienky použijú na zlepšenie produktov a služieb spoločnosti Microsoft. Váš správca IT bude môcť tieto údaje zhromažďovať. Vyhlásenie o ochrane osobných údajov.

Ďakujeme za vaše pripomienky!

×