Šis straipsnis taikomas Microsoft Dynamics NAV rusų (ru) kalbos lokalės.

Požymiai

Rusijos versijoje Microsoft Dynamics NAV 2009 R2 su funkcijų paketas 1, jei lentelę PVM įrašas (254) yra PVM paskirstymo pakeitimus operacijas, kai bandote pakeisti užregistruoti formoje tiekėjo knygos įrašus, galite gauti tokį klaidos pranešimą:

Prekės Nr.Item_No. nėra.

Sprendimas

Karštųjų pataisų informacija

Palaikomą naujausią pataisą dabar yra Microsoft. Tačiau jos skirtos tik šiame straipsnyje aprašytai problemai spręsti. Taikyti ją tik sistemoms, kuriose kyla ši konkreti problema. Šios karštosios pataisos gali būti papildomai išbandoma. Todėl, jei jums nelabai trukdo Ši problema, rekomenduojame palaukti kito "Microsoft Dynamics NAV 2009" pakeitimų paketo arba kitą versiją Microsoft Dynamics NAV, kuriame bus šios karštosios pataisos.Pastaba. Konkrečiais atvejais už palaikymo skambučius gali būti atšaukti, jei techninės pagalbos specialistas Microsoft Dynamics ir susijusių produktų taikomi įprasti mokesčiai nustato, kad jūsų problemą galima išspręsti naudojant konkretų naujinimą. Į įprastos kainos už palaikymą taikomos papildomos palaikymo klausimams ir problemoms, kurių negalima išspręsti naudojant minėtą naujinimą.

Diegimo informacija

"Microsoft" pateikia programavimo pavyzdžius tik, tačiau nesuteikia jokių aiškių arba numanomų garantijų. Tai apima, bet neapsiribojant, numanomas garantijas dėl perkamumo ir tinkamumo konkrečiam tikslui. Šis straipsnis parašytas galvojant, kad esate susipažinę su pateikta programavimo kalba ir įrankiais, kurie yra naudojami procedūroms kurti ir derinti. "Microsoft" palaikymo inžinieriai gali padėti paaiškindami tam tikros procedūros funkcinę galimybę, tačiau jie nekeis šių pavyzdžių, kad numatytų papildomą funkcinę galimybę arba sukurtų konkrečius jūsų reikalavimus atitinkančias procedūras.Pastaba. Prieš diegdami šias karštąsias pataisas, patikrinkite, kad visi Microsoft Navision klientas vartotojai išsiregistravę sistema. Tai reiškia, kad Microsoft Navision programos paslaugos (NAS) kliento naudotojai. Jums turėtų būti tik kliento vartotojo, kuris yra prisijungęs, kai atliekate šias karštąsias pataisas.Norint pritaikyti šią karštąją pataisą, turite programų kūrėjo licencijos.Rekomenduojame, kad vartotojo abonemento Windows registravimosi lange arba duomenų bazės prisijungimų langas būti priskirta "SUPER" vaidmenį ID. Jei vartotojo abonementas negali būti priskirta "SUPER" ID., turi patikrinti, kad vartotojo abonementas turi šias teises:

  • Keisti teisės objektas, kuris bus pakeisti.

  • Teisės vykdyti sistemos objekto ID 5210 objekto ir sistemos objekto ID 9015 objekto.

Pastaba. Jūs neturite turėti teisių į duomenų saugyklų, nebent jūs turite atlikti duomenų atkūrimo.

Pastaba.

Pastaba. Visada bandymas kodas nustato kontroliuojamoje aplinkoje prieš taikydami nustato savo gamybos kompiuteriams.Norėdami išspręsti šią problemą, atlikite šiuos veiksmus:Pastaba. Norėdami sukurti lauką (12490), naudokite šį .fob failą.

Failo vardas

Failo versija

Failo dydis

Data

Laikas

Platforma

Vstf260227.fob

Netaikoma

169,340

03-Jun-2011

10:08

Netaikoma

Šį failą galima atsisiųsti iš Microsoft Dynamics failą Exchange serverio:

https://mbs2.microsoft.com/fileexchange/?fileID=5f52394d-7020-4d24-98b4-909002c45cfeIšleidimo data: Balandžio 2, 2014„Microsoft“ patikrino, ar šiame faile nėra virusų. „Microsoft“ naudojo naujausią virusų aptikimo programinę įrangą, kuri buvo pasiekiama failo paskelbimo dieną. Failas laikomas padidintos saugos serveriuose, siekiant užkirsti kelią neleistinam failo modifikavimui.

  1. Pakeisti Atstatymas įrašų lentelėje (179) taip:

    1. Įtraukti šį lauką: {12490; PVM priskyrimo; Boolean}

    2. Pakeisti InsertReversalEntry funkcija:Esamas kodas

      ...                  ReversalEntry."Bal. Account Type" := GLEntry."Bal. Account Type";                ReversalEntry."Bal. Account No." := GLEntry."Bal. Account No.";                ReversalEntry."Line No." := NextLineNo;                NextLineNo := NextLineNo + 1;                ReversalEntry.INSERT;                IF GLEntry.Amount > 0 THEN BEGIN                  GLItemLedgRelation.RESET;                  GLItemLedgRelation.SETRANGE("G/L Entry No.",GLEntry."Entry No.");...

      Pastaba.

      ...                 ReversalEntry."Bal. Account Type" := GLEntry."Bal. Account Type";                ReversalEntry."Bal. Account No." := GLEntry."Bal. Account No.";                ReversalEntry."Line No." := NextLineNo;// Add the following line.                ReversalEntry."VAT Allocation" := VATAllocOnCost; // End of the added line.                NextLineNo := NextLineNo + 1;                ReversalEntry.INSERT;                IF GLEntry.Amount >0 THEN BEGIN                  GLItemLedgRelation.RESET;                 GLItemLedgRelation.SETRANGE("G/L Entry No.",GLEntry."Entry No."); ...
    3. Pakeisti CheckEntries funkcija:Esamas kodas 1

      ...    PROCEDURE CheckEntries@14();   ...

      Atsarginis kodas 1

      ...   PROCEDURE CheckEntries@14(IsVATAllocOnCost@1000000000 : Boolean);        ...

      Esamas kodas 2

      ...      MaxPostingDate := 0D;      IF NOT GLEntry.FIND('-') THEN        ERROR(Text009,GLEntry.TABLECAPTION,GLAcc.TABLECAPTION);// Delete the following line.      VATAllocOnCost := VATAllocationExist(VATEntry); // End of the deleted line.      IF GLEntry.FIND('-') THEN BEGIN// Delete the following line.        IF (GLEntry."Journal Batch Name" = '') AND NOT VATAllocOnCost THEN // End of the deleted line.          TestFieldError;        REPEAT          CheckGLAcc(GLEntry,BalanceCheckAmount,BalanceCheckAddCurrAmount);        UNTIL GLEntry.NEXT = 0;      END;    ...

      Atsarginis kodas 2

      ...         MaxPostingDate := 0D;      IF NOT GLEntry.FIND('-') THEN        ERROR(Text009,GLEntry.TABLECAPTION,GLAcc.TABLECAPTION);      IF GLEntry.FIND('-') THEN BEGIN// Add the following line.        IF (GLEntry."Journal Batch Name" = '') AND NOT IsVATAllocOnCost THEN// End of the added line.          TestFieldError;        REPEAT          CheckGLAcc(GLEntry,BalanceCheckAmount,BalanceCheckAddCurrAmount);        UNTIL GLEntry.NEXT = 0;      END;...

      Esamas kodas 3

      ...       IF VATEntry.FIND('-') THEN        REPEAT          CheckVAT(VATEntry);        UNTIL VATEntry.NEXT = 0;// Delete the following line.      IF VATAllocOnCost THEN // End of the deleted line.        IF ValueEntry.FIND('-') THEN          REPEAT            CheckItem(ValueEntry);          UNTIL ValueEntry.NEXT = 0;   ...

      Pakeitimo kodas 3

      ...       IF VATEntry.FIND('-') THEN        REPEAT          CheckVAT(VATEntry);        UNTIL VATEntry.NEXT = 0;// Add the following line.      IF IsVATAllocOnCost THEN // End of the added line.        IF ValueEntry.FIND('-') THEN          REPEAT            CheckItem(ValueEntry);          UNTIL ValueEntry.NEXT = 0;  ...
    4. Pakeisti SetReverseFilter funkcija:Esamas kodas 1

      ...           TaxDiffEntry.SETRANGE("Transaction No.",Number);      END ELSE BEGIN        GLReg.GET(Number); ...

      Atsarginis kodas 1

      ...         TaxDiffEntry.SETRANGE("Transaction No.",Number);// Add the following line.       ValueEntry.SETRANGE("Entry No.",0); // End of the added line.      END ELSE BEGIN        GLReg.GET(Number);...

      Esamas kodas 2

      ...           VATEntry.SETRANGE("Entry No.",GLReg."From VAT Entry No.",GLReg."To VAT Entry No.");        GLItemLedgRelation.SETCURRENTKEY(GLItemLedgRelation."G/L Register No.");        GLItemLedgRelation.SETRANGE("G/L Register No.",GLReg."No.");        IF GLItemLedgRelation.FINDFIRST THEN          FromValueEntryNo := GLItemLedgRelation."Value Entry No.";        IF GLItemLedgRelation.FINDLAST THEN          ToValueEntryNo := GLItemLedgRelation."Value Entry No.";        ValueEntry.SETRANGE("Entry No.",FromValueEntryNo,ToValueEntryNo); ...

      Atsarginis kodas 2

      ...        VATEntry.SETRANGE("Entry No.",GLReg."From VAT Entry No.",GLReg."To VAT Entry No.");// Add the following lines.        FromValueEntryNo := 0;         ToValueEntryNo := 0;         IF VATAllocOnCost THEN BEGIN // End of the added lines.          GLItemLedgRelation.SETCURRENTKEY(GLItemLedgRelation."G/L Register No.");          GLItemLedgRelation.SETRANGE("G/L Register No.",GLReg."No.");          IF GLItemLedgRelation.FINDFIRST THEN            FromValueEntryNo := GLItemLedgRelation."Value Entry No.";          IF GLItemLedgRelation.FINDLAST THEN            ToValueEntryNo := GLItemLedgRelation."Value Entry No.";// Add the following line.        END;// End of the added line.        ValueEntry.SETRANGE("Entry No.",FromValueEntryNo,ToValueEntryNo);  ...
    5. Pakeisti VATAllocationExist funkcija:Esamas kodas

      ...// Delete the following line.       VATEntry2.COPYFILTERS(VATEntry2); // End of the deleted line.      VATEntry2.SETRANGE("VAT Allocation Type",VATEntry2."VAT Allocation Type"::Charge);      EXIT(NOT VATEntry2.ISEMPTY);   ...

      Pastaba.

      ...// Add the following line.       VATEntry2.COPYFILTERS(VATEntry); // End of the added line.      VATEntry2.SETRANGE("VAT Allocation Type",VATEntry2."VAT Allocation Type"::Charge);      EXIT(NOT VATEntry2.ISEMPTY);  ...
  2. Pakeisti Post funkcija, t. y. Pakeisti įrašai (179) taip:Pridėkite nurodytą vietos kintamąjį:

    • Vardas: VATAllocOnCost

    • Duomenų tipas: loginis kintamasis

    Esamas kodas 1

    ...            IF TempGLReg.FINDSET THEN            REPEAT              ReversalEntry2.SetReverseFilter(TempGLReg."No.","Reversal Type");// Delete the following line.              ReversalEntry2.CheckEntries;  // End of the deleted line.              GET(1);              IF "Reversal Type" = "Reversal Type"::Register THEN                Number := TempGLReg."No."              ELSE                Number := "Transaction No."; ...

    Atsarginis kodas 1

    ...             IF TempGLReg.FINDSET THEN            REPEAT// Add the following lines.              SETRANGE("G/L Register No.",TempGLReg."No.");               SETRANGE("VAT Allocation",TRUE);               VATAllocOnCost := NOT ISEMPTY; // End of the added lines.              ReversalEntry2.SetReverseFilter(TempGLReg."No.","Reversal Type");// Add the following line.              ReversalEntry2.CheckEntries(VATAllocOnCost); // End of the added line.              GET(1);              IF "Reversal Type" = "Reversal Type"::Register THEN                Number := TempGLReg."No."              ELSE                Number := "Transaction No.";...

    Esamas kodas 2

    ...          UNTIL TempGLReg.NEXT = 0;        END ELSE BEGIN          ReversalEntry2.SetReverseFilter("Transaction No.","Reversal Type");// Delete the following line.          ReversalEntry2.CheckEntries; // End of the deleted line.          GET(1);          IF "Reversal Type" = "Reversal Type"::Register THEN            Number := "G/L Register No."    ...

    Atsarginis kodas 2

    ...             UNTIL TempGLReg.NEXT = 0;        END ELSE BEGIN// Add the following lines.          SETRANGE("G/L Register No.",TempGLReg."No.");           SETRANGE("VAT Allocation",TRUE);           VATAllocOnCost := NOT ISEMPTY; // End of the added lines.          ReversalEntry2.SetReverseFilter("Transaction No.","Reversal Type");// Add the following line.          ReversalEntry2.CheckEntries(VATAllocOnCost); // End of the added line.          GET(1);          IF "Reversal Type" = "Reversal Type"::Register THEN            Number := "G/L Register No." ...

Būtinosios sąlygos

Turite turėti Rusijos versiją Microsoft Dynamics NAV 2009 R2 funkcija 1 pakeitimų paketo norint taikyti šias karštąsias pataisas.

Pašalinimo informacija

Jūs negalite pašalinti šias karštąsias pataisas.

Būsena

„Microsoft“ patvirtino, kad tai yra „Microsoft“ produktų, išvardytų skyriuje „Taikoma“, problema.

Nuorodos

VSTF DynamicsNAV SE: 260227

Pastaba. Tai yra "GREITAI PUBLIKUOJAMAS" straipsnis, sukurtas tiesiogiai Microsoft palaikymo tarnybos. Čia pateikta informacija yra atsakas į kylančius klausimus. Dėl greito publikavimo medžiagoje gali būti spausdinimo klaidų ir ji gali būti peržiūrima bet kuriuo metu be įspėjimo. Naudojimo ieškokite kitų priežasčių.

Reikia daugiau pagalbos?

Norite daugiau parinkčių?

Sužinokite apie prenumeratos pranašumus, peržiūrėkite mokymo kursus, sužinokite, kaip apsaugoti savo įrenginį ir kt.

Bendruomenės padeda užduoti klausimus ir į juos atsakyti, pateikti atsiliepimų ir išgirsti iš ekspertų, turinčių daug žinių.