Príznaky
Nesprávne typ pri importovaní súborov LSV DD (bezhotovostné) a odmietnuté platby existuje vo Švajčiarsku verziu Microsoft Dynamics NAV 2009. Pri platbe bola zrušená, typ dokumentu sa nastaviť platby. Vzhľadom na nesprávne označenie množstva však nemôžete zaúčtovať položky. Postupujte podľa pokynov zmeny kódu sekcia na riešenie tohto problému. Tento problém sa vyskytuje v nasledovných produktov:
-
Švajčiarsku verziu Microsoft Dynamics NAV 2009 R2
-
Švajčiarsku verziu 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 globálne premenné LSVMgt procedúra (3010831):
Existujúci kód...Text11500@1150080 : TextConst 'ENU=Could not find Transaction No. %1 in Debit Direct Order No. %2.';
FileMgt@1150042 : Codeunit 419; FileSystemObject@1150081 : Automation "{420B2830-E718-11CF-893D-00A0C9054228} 1.0:{0D43FE01-F093-11CF-8940-00A0C9054228}:'Microsoft Scripting Runtime'.FileSystemObject"; PROCEDURE ReleaseCustLedgEntries@1(_GenJnlLine@1150000 : Record 81); BEGIN ...Nahradenie kódu
...Text11500@1150080 : TextConst 'ENU=Could not find Transaction No. %1 in Debit Direct Order No. %2.';
FileMgt@1150042 : Codeunit 419; FileSystemObject@1150081 : Automation "{420B2830-E718-11CF-893D-00A0C9054228} 1.0:{0D43FE01-F093-11CF-8940-00A0C9054228}:'Microsoft Scripting Runtime'.FileSystemObject"; // Add the following line. IsCancellationExist@1150082 : Boolean; // End of the added line. PROCEDURE ReleaseCustLedgEntries@1(_GenJnlLine@1150000 : Record 81); BEGIN ... -
Zmena kódu v ImportDebitDirectFile funkcia v LSVMgt procedúra (3010831):
Nahradenie kód 1...FeeAmount := 0;
TotalRecRecords := 0; TotalRecRecordsRev := 0; // Journal name for no serie GlBatchName.GET(ActGenJnlLine."Journal Template Name",ActGenJnlLine."Journal Batch Name"); ...Nahradenie kód 1
...FeeAmount := 0;
TotalRecRecords := 0; TotalRecRecordsRev := 0; // Add the following line. IsCancellationExist := FALSE; // End of the added line. // Journal name for no serie GlBatchName.GET(ActGenJnlLine."Journal Template Name",ActGenJnlLine."Journal Batch Name"); ...Existujúci kód 2
...// Split File line into fields
// Delete the following lines. FileID := COPYSTR(Line,1,3); IF FileID <> '036' THEN ERROR(Text049 + Text011); TA := COPYSTR(Line,36,2); IF NOT (TA = '97') THEN BEGIN TotalRecord := FALSE; EVALUATE(InvoiceAmt,COPYSTR(Line,54,13)); EVALUATE(yyCR,COPYSTR(Line,4,2)); EVALUATE(mmCR,COPYSTR(Line,6,2)); EVALUATE(ddCR,COPYSTR(Line,8,2)); IF yyCR > 98 THEN PostDate := DMY2DATE(ddCR,mmCR,1900 + yyCR) ELSE PostDate := DMY2DATE(ddCR,mmCR,2000 + yyCR); DebitDirectOrderNo := COPYSTR(Line,34,2); EVALUATE(DebitDirectRecordNo,COPYSTR(Line,38,6)); EVALUATE(RejectionCode,COPYSTR(Line,543,2)); Currency := COPYSTR(Line,51,3); // DEBIT DIRECT LsvJour.RESET; LsvJour.SETRANGE("Credit Date",PostDate); LsvJour.SETRANGE("DebitDirect Orderno.",DebitDirectOrderNo); IF NOT LsvJour.FIND('+') THEN ERROR(Text059,DebitDirectOrderNo,PostDate); LsvJournalLine.RESET; //CH0001.begin LsvJournalLine.SETCURRENTKEY("LSV Journal No.","Transaction No."); LsvJournalLine.SETRANGE("LSV Journal No.",LsvJour."No."); //LsvJournalLine.SETRANGE("Line No.",DebitDirectRecordNo); LsvJournalLine.SETRANGE("Transaction No.",DebitDirectRecordNo); //LsvJournalLine.FIND('-'); IF NOT LsvJournalLine.FINDFIRST THEN BEGIN d.CLOSE; ERROR(Text11500, DebitDirectRecordNo, DebitDirectOrderNo); END; //CH0001.end InInvoiceNo := LsvJournalLine."Applies-to Doc. No."; // END DEBIT DIRECT // Process transaction of credit record CASE TA OF '81': // Credit BEGIN Transaction := Transaction::Credit; LsvJournalLine."LSV Status" := LsvJournalLine."LSV Status"::Open; LsvJournalLine."DD Rejection Reason" := LsvJournalLine."DD Rejection Reason"::" "; LsvJournalLine.MODIFY; IF LSVSetup.READPERMISSION THEN BEGIN ClosedByESR(InInvoiceNo); END; END; '84': // Cancellation "Storno" BEGIN IF RejectionCode <> 2 THEN Transaction := Transaction::Correction ELSE Transaction := Transaction::Cancellation; LsvJournalLine."LSV Status" := LsvJournalLine."LSV Status"::Rejected; LsvJournalLine."DD Rejection Reason" := RejectionCode; LsvJournalLine.MODIFY; END; ELSE ERROR(Text023 + Text011); END; END ELSE BEGIN TotalRecord := TRUE; EVALUATE(TempAmount,COPYSTR(Line,60,13)); CreditAmount := CreditAmount + TempAmount / 100; EVALUATE(TempAmount,COPYSTR(Line,82,13)); RejectionAmount := RejectionAmount + TempAmount / 100; EVALUATE(TempAmount,COPYSTR(Line,104,13)); ReversalAmount := ReversalAmount + TempAmount / 100; EVALUATE(TempAmount,COPYSTR(Line,120,11)); FeeAmount := FeeAmount + TempAmount / 100; // Credit Count EVALUATE(TempAmount,COPYSTR(Line,54,6)); TotalRecRecords := TotalRecRecords + TempAmount; // Rejection Count EVALUATE(TempAmount,COPYSTR(Line,76,6)); TotalRecRecordsRev := TotalRecRecordsRev + TempAmount; // Reversal Count EVALUATE(TempAmount,COPYSTR(Line,98,6)); TotalRecRecordsRev := TotalRecRecordsRev + TempAmount; END; // END OF SPLIT IF NOT (TotalRecord) AND (Transaction <> Transaction::Correction) THEN BEGIN // End of the deleted lines. // Insert GL line GenJournalLine.INIT; GenJournalLine."Journal Template Name" := ActGenJnlLine."Journal Template Name"; ...Nahradenie kód 2
...// Split File line into fields
// Add the following lines. FileID := COPYSTR(Line,1,3); IF FileID <> '036' THEN ERROR(Text049 + Text011); TA := COPYSTR(Line,36,2); IF NOT (TA = '97') THEN BEGIN TotalRecord := FALSE; EVALUATE(InvoiceAmt,COPYSTR(Line,54,13)); EVALUATE(yyCR,COPYSTR(Line,4,2)); EVALUATE(mmCR,COPYSTR(Line,6,2)); EVALUATE(ddCR,COPYSTR(Line,8,2)); IF yyCR > 98 THEN PostDate := DMY2DATE(ddCR,mmCR,1900 + yyCR) ELSE PostDate := DMY2DATE(ddCR,mmCR,2000 + yyCR); DebitDirectOrderNo := COPYSTR(Line,34,2); EVALUATE(DebitDirectRecordNo,COPYSTR(Line,38,6)); EVALUATE(RejectionCode,COPYSTR(Line,543,2)); Currency := COPYSTR(Line,51,3); // DEBIT DIRECT LsvJour.RESET; LsvJour.SETRANGE("Credit Date",PostDate); LsvJour.SETRANGE("DebitDirect Orderno.",DebitDirectOrderNo); IF NOT LsvJour.FIND('+') THEN ERROR(Text059,DebitDirectOrderNo,PostDate); LsvJournalLine.RESET; //CH0001.begin LsvJournalLine.SETCURRENTKEY("LSV Journal No.","Transaction No."); LsvJournalLine.SETRANGE("LSV Journal No.",LsvJour."No."); //LsvJournalLine.SETRANGE("Line No.",DebitDirectRecordNo); LsvJournalLine.SETRANGE("Transaction No.",DebitDirectRecordNo); //LsvJournalLine.FIND('-'); IF NOT LsvJournalLine.FINDFIRST THEN BEGIN d.CLOSE; ERROR(Text11500, DebitDirectRecordNo, DebitDirectOrderNo); END; //CH0001.end InInvoiceNo := LsvJournalLine."Applies-to Doc. No."; // END DEBIT DIRECT // Process transaction of credit record CASE TA OF '81': // Credit BEGIN Transaction := Transaction::Credit; LsvJournalLine."LSV Status" := LsvJournalLine."LSV Status"::Open; LsvJournalLine."DD Rejection Reason" := LsvJournalLine."DD Rejection Reason"::" "; LsvJournalLine.MODIFY; IF LSVSetup.READPERMISSION THEN BEGIN ClosedByESR(InInvoiceNo); END; END; '84': // Cancellation "Storno" BEGIN IF RejectionCode <> 2 THEN Transaction := Transaction::Correction ELSE Transaction := Transaction::Cancellation; LsvJournalLine."LSV Status" := LsvJournalLine."LSV Status"::Rejected; LsvJournalLine."DD Rejection Reason" := RejectionCode; LsvJournalLine.MODIFY; END; ELSE ERROR(Text023 + Text011); END; END ELSE BEGIN TotalRecord := TRUE; EVALUATE(TempAmount,COPYSTR(Line,60,13)); CreditAmount := CreditAmount + TempAmount / 100; EVALUATE(TempAmount,COPYSTR(Line,82,13)); RejectionAmount := RejectionAmount + TempAmount / 100; EVALUATE(TempAmount,COPYSTR(Line,104,13)); ReversalAmount := ReversalAmount + TempAmount / 100; EVALUATE(TempAmount,COPYSTR(Line,120,11)); FeeAmount := FeeAmount + TempAmount / 100; // Credit Count EVALUATE(TempAmount,COPYSTR(Line,54,6)); TotalRecRecords := TotalRecRecords + TempAmount; // Rejection Count EVALUATE(TempAmount,COPYSTR(Line,76,6)); TotalRecRecordsRev := TotalRecRecordsRev + TempAmount; // Reversal Count EVALUATE(TempAmount,COPYSTR(Line,98,6)); TotalRecRecordsRev := TotalRecRecordsRev + TempAmount; END; // END OF SPLIT IF NOT (TotalRecord) AND (Transaction <> Transaction::Correction) THEN BEGIN // End of the added lines. // Insert GL line GenJournalLine.INIT; GenJournalLine."Journal Template Name" := ActGenJnlLine."Journal Template Name"; ...Existujúci kód 3
...GenJournalLine.INIT;
GenJournalLine."Journal Template Name" := ActGenJnlLine."Journal Template Name"; GenJournalLine."Journal Batch Name" := ActGenJnlLine."Journal Batch Name"; LastLineNo := LastLineNo + 10000; GenJournalLine."Line No." := LastLineNo; GenJournalLine."Document No." := NextDocNo; ...Nahradenie kód 3
... GenJournalLine.INIT;
GenJournalLine."Journal Template Name" := ActGenJnlLine."Journal Template Name"; GenJournalLine."Journal Batch Name" := ActGenJnlLine."Journal Batch Name"; // Add the following lines. GenJournalLine."Posting Date" := PostDate; GenJournalLine."Account Type" := GenJournalLine."Account Type"::Customer; IF Transaction = Transaction::Cancellation THEN BEGIN IsCancellationExist := TRUE; GenJournalLine."Document Type" := GenJournalLine."Document Type"::Refund; NextDocNo := NoSeriesMgt.GetNextNo(GlBatchName."No. Series",PostDate,FALSE); END ELSE GenJournalLine."Document Type" := GenJournalLine."Document Type"::Payment; // End of the added lines. LastLineNo := LastLineNo + 10000; GenJournalLine."Line No." := LastLineNo; GenJournalLine."Document No." := NextDocNo; ...Existujúci kód 4
...LastLineNo := LastLineNo + 10000;
GenJournalLine."Line No." := LastLineNo; GenJournalLine."Document No." := NextDocNo; // Delete the following lines. GenJournalLine."Posting Date" := PostDate; GenJournalLine."Account Type" := GenJournalLine."Account Type"::Customer; GenJournalLine."Document Type" := GenJournalLine."Document Type"::Payment; // End of the deleted lines. GeneralLedgerSetup.GET; IF GeneralLedgerSetup."LCY Code" <> Currency THEN ...Nahradenie kód 4
... LastLineNo := LastLineNo + 10000;
GenJournalLine."Line No." := LastLineNo; GenJournalLine."Document No." := NextDocNo; // Add the following lines. IF Transaction = Transaction::Cancellation THEN NextDocNo := NoSeriesMgt.GetNextNo(GlBatchName."No. Series",PostDate,FALSE); // End of the added lines. GeneralLedgerSetup.GET; IF GeneralLedgerSetup."LCY Code" <> Currency THEN ...Existujúci kód 5
... IF CustLedgerEntry.FIND('-') THEN
GenJournalLine.VALIDATE("Account No.",CustLedgerEntry."Customer No."); // Delete the following lines. GenJournalLine."Applies-to Doc. Type" := GenJournalLine."Applies-to Doc. Type"::Invoice; GenJournalLine."Applies-to Doc. No." := InInvoiceNo; // End of the deleted lines. IF GenJournalLine."Currency Code" <> CustLedgerEntry."Currency Code" THEN GenJournalLine.VALIDATE("Currency Code",CustLedgerEntry."Currency Code"); ...Nahradenie kód 5
... IF CustLedgerEntry.FIND('-') THEN
GenJournalLine.VALIDATE("Account No.",CustLedgerEntry."Customer No."); // Add the following lines. IF Transaction <> Transaction::Cancellation THEN BEGIN GenJournalLine."Applies-to Doc. Type" := GenJournalLine."Applies-to Doc. Type"::Invoice; GenJournalLine."Applies-to Doc. No." := InInvoiceNo; END; // End of the added lines. IF GenJournalLine."Currency Code" <> CustLedgerEntry."Currency Code" THEN GenJournalLine.VALIDATE("Currency Code",CustLedgerEntry."Currency Code"); ...Existujúci kód 6
...// *** Bal account per line or as combined entry
// Delete the following line. IF MultiplePostingDates THEN BEGIN // End of the deleted line. // Bal Account per line IF GenJournalLine.FIND('-') THEN REPEAT ...Nahradenie kód 6
...// *** Bal account per line or as combined entry
// Add the following line. IF MultiplePostingDates OR IsCancellationExist THEN BEGIN // End of the added line. // Bal Account per line IF GenJournalLine.FIND('-') THEN REPEAT ...
Požiadavky
Musíte mať jednu z nasledovných produktov nainštalovaný chcete použiť túto rýchlu opravu:
-
Švajčiarsku verziu Microsoft Dynamics NAV 2009 R2
-
Švajčiarsku verziu 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ť kedykoľvek bez predchádzajúceho upozornenia. Prečítajte si Podmienky používaniaz iných dôvodov.