"Transakcia nemôže dokončiť, pretože spôsobí nekonzistencie v tabuľke Finančná položka" chybové hlásenie pri pokuse zaúčtovať platby z denníka príjmu hotovosti v španielskej verzii systému Microsoft Dynamics NAV 2009 Service Pack 1

Šablóna: CPR - Navision kód opraviť šablóny

BUG #: 137139 (údržby)BUG #: 57797 (Vedbaek SE)

Tento článok sa vzťahuje na Microsoft Dynamics NAV pre španielsky (es) jazyk locale.

Príznaky

Pri pokuse o post platby z denníka príjmu hotovosti v španielskej verzii systému Microsoft Dynamics NAV 2009 Service Pack 1 (SP1), zobrazí nasledujúce chybové hlásenie:

Transakcia sa nedá dokončiť, pretože spôsobí nekonzistencie v tabuľke Finančná položka

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.

Ak táto rýchla oprava nie je verejne prístupná na prevzatie (čo znamená, v tomto článku sa neuvádza verejná adresa URL pre túto rýchlu opravu), distribúcia vyžaduje technické vedenie, členom eskalačného tímu alebo nadriadeným a platí nasledovné:

  • Získať rýchlu opravu, musí zákazníkov vyskytujú chyby, ktoré je spomenuté v časti "Príznaky".

  • Musíte sledovať zákazníkov to Odoslať a dodať im najnovší balík service pack po sprístupnení (v prípade, že takýto balík vydaný).

Táto oprava sa neplánuje ako súčasť Microsoft Dynamics NAV service pack.



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 vám môžu vysvetliť fungovanie konkrétneho postupu, ale neupravia tieto príklady s cieľom poskytnutia pridanej funkčnosti ani nevytvoria procedúry zohľadňujúce vaše konkrétne požiadavky.

Poznámka: Skôr než nainštalujete túto rýchlu opravu, overte, že všetky Microsoft Navision klienta používatelia odhlásení systému. Toto zahŕňa používateľov klienta Microsoft Navision aplikácie služby (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úča sa, že konto používateľa 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 objektu.



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 ApplyCustLedgEntry funkcia v Gen. denníkov.-Post riadok procedúra (12) takto:
    Existujúci kód

    ...IF NOT TempOldCustLedgEntry.FIND('-') THEN
    EXIT;
    AppliesToDocType := TempOldCustLedgEntry."Document Type";
    END;
    IF OldCustLedgEntry."Document Type" = OldCustLedgEntry."Document Type"::Bill THEN BEGIN
    ...

    Nahradenie kódu

    ...IF NOT TempOldCustLedgEntry.FIND('-') THEN
    EXIT;

    // Add the following line.
    IF GenJnlLine."Applies-to ID" = '' THEN

    AppliesToDocType := TempOldCustLedgEntry."Document Type";
    END;
    IF OldCustLedgEntry."Document Type" = OldCustLedgEntry."Document Type"::Bill THEN BEGIN
    ...

  2. Zmena kódu v ApplyVendLedgEntry funkcia v Gen. denníkov.-Post riadok procedúra (12) takto:
    Existujúci kód

    ...IF NOT TempOldVendLedgEntry.FIND('-') THEN
    EXIT;
    AppliesToDocType := TempOldVendLedgEntry."Document Type";
    END;
    IF OldVendLedgEntry."Document Type" = OldVendLedgEntry."Document Type"::Bill THEN BEGIN
    ...

    Nahradenie kódu

    ...IF NOT TempOldVendLedgEntry.FIND('-') THEN
    EXIT;

    // Add the following line.
    IF GenJnlLine."Applies-to ID" = '' THEN

    AppliesToDocType := TempOldVendLedgEntry."Document Type";
    END;
    IF OldVendLedgEntry."Document Type" = OldVendLedgEntry."Document Type"::Bill THEN BEGIN
    ...

  3. Zmeňte kód v kód funkcia v Gen. denníkov.-dávkové Post procedúra (13) takto:
    Nahradenie kód 1

    ...IF GenJnlLine."Applies-to ID" <> '' THEN
    IF GenJnlLine."Account Type" = GenJnlLine."Account Type"::Customer THEN BEGIN
    CustLedgEntry.SETRANGE("Applies-to ID",GenJnlLine."Applies-to ID");
    ...

    Nahradenie kód 1

    ...IF GenJnlLine."Applies-to ID" <> '' THEN
    IF GenJnlLine."Account Type" = GenJnlLine."Account Type"::Customer THEN BEGIN

    // Add the following lines.
    CustLedgEntry.RESET;
    CustLedgEntry.SETRANGE("Customer No.","Account No.");
    // End of the lines.

    CustLedgEntry.SETRANGE("Applies-to ID",GenJnlLine."Applies-to ID");
    ...

    Existujúci kód 2

    ...IF GenJnlLine."Account Type" = GenJnlLine."Account Type"::Vendor THEN BEGIN
    VendLedgEntry.SETRANGE("Applies-to ID",GenJnlLine."Applies-to ID");
    VendLedgEntry.SETRANGE("Document Type",VendLedgEntry."Document Type"::Bill);
    ...

    Nahradenie kód 2

    ...IF GenJnlLine."Account Type" = GenJnlLine."Account Type"::Vendor THEN BEGIN

    // Add the following lines.
    VendLedgEntry.RESET;
    VendLedgEntry.SETRANGE("Vendor No.","Account No.");
    // End of the lines.

    VendLedgEntry.SETRANGE("Applies-to ID",GenJnlLine."Applies-to ID");
    VendLedgEntry.SETRANGE("Document Type",VendLedgEntry."Document Type"::Bill);
    ...

Požiadavky

Španielskej verzii systému Microsoft Dynamics NAV 2009 Service Pack 1 nainštalovaný chcete použiť túto rýchlu opravu, musíte mať.

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žívania z iných dôvodov.

Autor: avannini
Writer: v-brialu
Tech Reviewer: avannini
Editor:

Potrebujete ďalšiu pomoc?

Rozšírte svoje zručnosti
Preskúmať školenie
Buďte medzi prvými, ktorí získajú nové funkcie
Pripojiť k Microsoft insiderov chcú

Považujete poskytnuté informácie za užitočné?

Ďakujem za vaše pripomienky!

Ďakujeme vám za pripomienky. Pravdepodobne vám pomôže, ak vás spojíme s pracovníkom podpory pre Office.

×