Netinkamas sąskaitos naudojamos registruojant sąskaitos vidinės įmonės pardavimo kredito pažymos arba sąskaitos vidinės įmonės pirkimo kredito pažymos Microsoft Dynamics NAV 2009


Šis straipsnis taikomas Microsoft Dynamics NAV visose šalyse ir visų kalbų aplinkos.

Požymiai


Registruojant sąskaitos vidinės įmonės pardavimo kredito pažymos arba sąskaitos vidinės įmonės pirkimo kredito pažymos Microsoft Dynamics NAV 2009, neteisingas abonementai naudojami atitinkami DK įrašai.
Ši problema iškyla faile šiems produktams:
  • Microsoft Dynamics NAV 2009 R2
  • Microsoft Dynamics NAV 2009 1 pakeitimų paketas (SP1)

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" pakeitimų paketo arba kitos Microsoft Dynamics NAV versijos, 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:
  1. Pakeisti InsertICGenJnlLine funkcija – pardavimo-Post Kodinys (80) kodą taip:
    Esamas kodas
    ...IF SalesHeader."Document Type" IN
    [SalesHeader."Document Type"::"Return Order",SalesHeader."Document Type"::"Credit Memo"]
    THEN
    TempICGenJnlLine.Amount :=

    // Delete the following line.
    -ROUND(

    CurrExchRate.ExchangeAmtFCYToLCY(
    SalesHeader."Posting Date",SalesLine."Currency Code",
    SalesLine.Amount,SalesHeader."Currency Factor"))
    ELSE
    TempICGenJnlLine.Amount :=

    // Delete the following line.
    ROUND(

    CurrExchRate.ExchangeAmtFCYToLCY(
    SalesHeader."Posting Date",SalesLine."Currency Code",
    SalesLine.Amount,SalesHeader."Currency Factor"));
    END ELSE BEGIN
    Currency.InitRoundingPrecision;
    TempICGenJnlLine."Currency Code" := SalesHeader."Currency Code";
    TempICGenJnlLine."Currency Factor" := SalesHeader."Currency Factor";
    IF SalesHeader."Document Type" IN [SalesHeader."Document Type"::"Return Order",SalesHeader."Document Type"::"Credit Memo"] THEN

    // Delete the following line.
    TempICGenJnlLine.Amount := -SalesLine.Amount

    ELSE
    // Delete the following line.
    TempICGenJnlLine.Amount := SalesLine.Amount;
    ...
    Pastaba.
    ...IF SalesHeader."Document Type" IN
    [SalesHeader."Document Type"::"Return Order",SalesHeader."Document Type"::"Credit Memo"]
    THEN
    TempICGenJnlLine.Amount :=

    // Add the following line.
    ROUND(

    CurrExchRate.ExchangeAmtFCYToLCY(
    SalesHeader."Posting Date",SalesLine."Currency Code",
    SalesLine.Amount,SalesHeader."Currency Factor"))
    ELSE
    TempICGenJnlLine.Amount :=

    // Add the following line.
    -ROUND(

    CurrExchRate.ExchangeAmtFCYToLCY(
    SalesHeader."Posting Date",SalesLine."Currency Code",
    SalesLine.Amount,SalesHeader."Currency Factor"));
    END ELSE BEGIN
    Currency.InitRoundingPrecision;
    TempICGenJnlLine."Currency Code" := SalesHeader."Currency Code";
    TempICGenJnlLine."Currency Factor" := SalesHeader."Currency Factor";
    IF SalesHeader."Document Type" IN [SalesHeader."Document Type"::"Return Order",SalesHeader."Document Type"::"Credit Memo"] THEN

    // Add the following line.
    TempICGenJnlLine.Amount := SalesLine.Amount

    ELSE

    // Add the following line.
    TempICGenJnlLine.Amount := -SalesLine.Amount;
    ...
  2. Pakeisti PostICPartner funkcija PostICPartner Kodinys (12):
    Esamas kodas
    ....WITH GenJnlLine DO BEGIN
    IF GenJnlLine."Account No." <> ICPartner.Code THEN
    ICPartner.GET("Account No.");

    // Delete the following line.
    IF GenJnlLine.Amount > 0 THEN BEGIN

    ICPartner.TESTFIELD("Receivables Account");
    AccountNo := ICPartner."Receivables Account";
    END ELSE BEGIN
    ICPartner.TESTFIELD("Payables Account");
    AccountNo := ICPartner."Payables Account";
    END;
    InitGLEntry(AccountNo,"Amount (LCY)","Source Currency Amount",TRUE,TRUE);
    GLEntry."Bal. Account Type" := GenJnlLine."Bal. Account Type";
    GLEntry."Bal. Account No." := GenJnlLine."Bal. Account No.";
    InsertGLEntry(TRUE);
    END;
    ...
    Pastaba.
    ....WITH GenJnlLine DO BEGIN
    IF "Account No." <> ICPartner.Code THEN
    ICPartner.GET("Account No.");

    // Add the following line.
    IF ("Document Type" = "Document Type"::"Credit Memo") XOR (Amount > 0) THEN BEGIN

    ICPartner.TESTFIELD("Receivables Account");
    AccountNo := ICPartner."Receivables Account";
    END ELSE BEGIN
    ICPartner.TESTFIELD("Payables Account");
    AccountNo := ICPartner."Payables Account";
    END;

    InitGLEntry(AccountNo,"Amount (LCY)","Source Currency Amount",TRUE,TRUE);
    GLEntry."Bal. Account Type" := "Bal. Account Type";
    GLEntry."Bal. Account No." := "Bal. Account No.";
    InsertGLEntry(TRUE);
    END;
    ...

Būtinosios sąlygos

Turi būti viena iš toliau nurodytų produktų, norint taikyti šias karštąsias pataisas:
  • Microsoft Dynamics NAV 2009 R2
  • Microsoft Dynamics NAV 2009 1 pakeitimų paketas (SP1)

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.
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ų.