Konta są eksportowane nieoczekiwanie podczas eksportowania raportu 10885 we francuskiej wersji systemu Microsoft Dynamics NAV 2009

Szablon: CPR — szablon Fiacx kodu systemu Navision

Nr błędu: 207246 (Obsługa zawartości)

Konta są eksportowane nieoczekiwanie podczas eksportowania raportu kontroli podatku (10885) we francuskiej wersji systemu Microsoft Dynamics NAV 2009. Wykonaj kroki opisane w sekcji zmiany kodu , aby rozwiązać ten problem. Ten problem występuje w następujących produktach:

  • Francuskiej wersji systemu Microsoft Dynamics NAV 2009 R2

  • Wersja francuska z dodatkiem Service Pack 1 (SP1) dla systemu Microsoft Dynamics NAV 2009

Rozwiązanie

Informacje o poprawce

Obsługiwana poprawka jest obecnie udostępniana przez firmę Microsoft. Jednak to jest przeznaczona tylko do usunięcia problemu opisanego w tym artykule. Zastosuj ją tylko w systemach, w których występuje ten problem. Ta poprawka może być wciąż w fazie testowania. Jeśli dany system nie jest poważnie narażony na ten problem, firma Microsoft zaleca, aby poczekać na następny dodatek service pack dla systemu Microsoft Dynamics NAV 2009 lub następną wersję systemu Microsoft Dynamics NAV, zawierający tę poprawkę.

Uwaga W wyjątkowych przypadkach opłaty, telefonujący do pomocy technicznej mogą zostać anulowane, jeśli pomocy technicznej dla systemu Microsoft Dynamics i produktów powiązanych Określa, że określonej aktualizacji, można rozwiązać swój problem. Koszty obsługi zwykłych zastosuje się do dodatkowych pytań i problemów, których nie można rozwiązać przy użyciu określonej aktualizacji.

Jeśli ta poprawka nie została ogłoszona do publicznego pobierania (tzn. publiczny adres URL tej poprawki nie jest podany w treści artykułu), dystrybucja wymaga akceptacji kierownika technicznego, starszego członka zespołu lub menedżera i stosuje się następujące informacje:

  • Aby otrzymać poprawkę, klient musi napotkać błąd, który jest wymieniony w sekcji "Symptomy".

  • Należy śledzić klientom wysyła się poprawkę i przesłać im następny dodatek service pack, kiedy będzie dostępny (Jeśli zostanie wydany dodatek service pack).

Ta poprawka nie jest uwzględniona zostanie uwzględniona w dodatku Microsoft Dynamics NAV Service Pack.

Informacje dotyczące instalacji

Firma Microsoft podaje przykłady programowania wyłącznie, bez jakichkolwiek gwarancji wyrażonych wprost lub domyślnie. To obejmuje, ale nie jest ograniczona, ustawowej rękojmi co do przydatności handlowej lub przydatności do określonego celu. W tym artykule założono, że użytkownik zna demonstrowany język programowania oraz narzędzia, które są używane do tworzenia i debugowania procedur. Wykwalifikowani pracownicy pomocy technicznej firmy Microsoft mogą pomóc w wyjaśnieniu, jak działa określona procedura. Nie będą jednak modyfikować tych przykładów ani dodawać funkcjonalności i konstruować procedur w celu zaspokojenia określonych potrzeb użytkownika.

Uwaga Przed zainstalowaniem tej poprawki należy zweryfikować, że wszyscy użytkownicy klienta systemu Microsoft Dynamics NAV są wylogowani systemu. Obejmuje to usług systemu Microsoft Dynamics NAV aplikacji serwera (NAS). Powinny być użytkownika klienta, który jest zalogowany w momencie wdrożyć tę poprawkę.

Aby wdrożyć tę poprawkę, musi mieć licencję deweloperską.

Firma Microsoft zaleca, aby do konta użytkownika w oknie identyfikatorów logowania systemu Windows lub w oknie identyfikatorów logowania bazy danych być przypisany identyfikator roli "SUPER". Jeśli konto użytkownika nie można przypisać Identyfikatora roli "SUPER", należy sprawdzić, czy konto użytkownika ma następujące uprawnienia:

  • Uprawnienie Modyfikacja dla obiektu, który będzie zmieniany.

  • Uprawnienie Execute obiektu 5210 identyfikator obiektu systemu i 9015 identyfikator obiektu systemu

    obiekt.

Uwaga Nie trzeba mieć prawa do magazynów danych, chyba że konieczne jest przeprowadzenie naprawy danych.

Zmiany kodu

Uwaga Zawsze test poprawki kodu w kontrolowanym środowisku przed zastosowaniem poprawki na komputerach produkcyjnych.

Aby rozwiązać ten problem, wykonaj następujące kroki:

  1. Zmień kod w oknie właściwości w wyeksportować zapisy K/G - sprawozdanie z kontroli podatku (10885) w następujący sposób:
    Istniejący kod 1

    ...ERROR(MissingStartingDateErr);
    IF EndingDate = 0D THEN
    ERROR(MissingEndingDateErr);

    GLEntry.SETRANGE("Posting Date",StartingDate,EndingDate);
    GLEntry.SETRANGE("Entry Type",GLEntry."Entry Type"::Definitive);
    ...

    Kod zastępczy 1

    ...ERROR(MissingStartingDateErr);
    IF EndingDate = 0D THEN
    ERROR(MissingEndingDateErr);

    // Add the following lines.
    IF GLAccount.GETFILTER("No.") <> '' THEN
    GLAccNoFilter := GLAccount.GETFILTER("No.");
    // End of the added lines.

    GLEntry.SETRANGE("Posting Date",StartingDate,EndingDate);
    GLEntry.SETRANGE("Entry Type",GLEntry."Entry Type"::Definitive);
    ...

    Istniejący kod 2

    ...GLEntry.SETRANGE("Posting Date",StartingDate,EndingDate);
    GLEntry.SETRANGE("Entry Type",GLEntry."Entry Type"::Definitive);
    IF GLEntry.ISEMPTY THEN
    ERROR(NoEntriestoExportErr);
    ...

    Kod zastępczy 2

    ...GLEntry.SETRANGE("Posting Date",StartingDate,EndingDate);
    GLEntry.SETRANGE("Entry Type",GLEntry."Entry Type"::Definitive);

    // Add the following line.
    GLEntry.SETFILTER("G/L Account No.",GLAccNoFilter);

    IF GLEntry.ISEMPTY THEN
    ERROR(NoEntriestoExportErr);
    ...
  2. Zmień kod w DataItemTable Table15 w wyeksportować zapisy K/G - sprawozdanie z kontroli podatku (10885) w następujący sposób:
    Istniejący kod 1

    ...DataItemTableView=SORTING(No.)
    WHERE(Account Type=CONST(Posting));
    DataItemVarName=GLAccount;
    OnAfterGetRecord=BEGIN
    IF IncludeOpeningBalances THEN
    WriteGLAccountToFile(GLAccount);
    ...

    Kod zastępczy 1

    ...DataItemTableView=SORTING(No.)
    WHERE(Account Type=CONST(Posting));
    DataItemVarName=GLAccount;

    // Add the following lines.
    OnPreDataItem=BEGIN
    SETFILTER("No.",GLAccNoFilter);
    END;
    // End of the added lines.

    OnAfterGetRecord=BEGIN
    IF IncludeOpeningBalances THEN
    WriteGLAccountToFile(GLAccount);
    ...

    Istniejący kod 2

    ...IF IncludeOpeningBalances THEN
    WriteGLAccountToFile(GLAccount);
    END;

    }
    SECTIONS
    {
    ...

    Kod zastępczy 2

    ...IF IncludeOpeningBalances THEN
    WriteGLAccountToFile(GLAccount);
    END;

    // Add the following line.
    ReqFilterFields=No.;

    }
    SECTIONS
    {
    ...
  3. Zmień kod w DataItemTable tabela17 w wyeksportować zapisy K/G - sprawozdanie z kontroli podatku (10885) w następujący sposób:
    Istniejący kod

    ...OnPreDataItem=BEGIN
    SETRANGE("Posting Date",StartingDate,EndingDate);
    SETRANGE("Entry Type","Entry Type"::Definitive);
    END;

    OnAfterGetRecord=BEGIN
    ...

    Kod zastępczy

    ...OnPreDataItem=BEGIN
    SETRANGE("Posting Date",StartingDate,EndingDate);
    SETRANGE("Entry Type","Entry Type"::Definitive);

    // Add the following line.
    SETFILTER("G/L Account No.",GLAccount.GETFILTER("No."));

    END;

    OnAfterGetRecord=BEGIN
    ...
  4. Zmień kod w zmiennych globalnych w wyeksportować zapisy K/G - sprawozdanie z kontroli podatku (10885) w następujący sposób:
    Istniejący kod

    ...OutputFileName@1120014 : Text[250];
    StartingDate@1120001 : Date;
    EndingDate@1120002 : Date;
    ReportFileName@1120003 : Text[250];
    ReportFilePath@1120019 : Text[250];
    FileTypeTxt@1120005 : TextConst 'ENU=Text Files (*.txt)|*.txt|All Files (*.*)|*.*';
    ...

    Kod zastępczy

    ...
    OutputFileName@1120014 : Text[250];
    StartingDate@1120001 : Date;
    EndingDate@1120002 : Date;

    // Add the following line.
    GLAccNoFilter@1120006 : Code[250];

    ReportFileName@1120003 : Text[250];
    ReportFilePath@1120019 : Text[250];
    FileTypeTxt@1120005 : TextConst 'ENU=Text Files (*.txt)|*.txt|All Files (*.*)|*.*';
    ...
  5. Zmień kod w funkcji Init w wyeksportować zapisy K/G - sprawozdanie z kontroli podatku (10885) w następujący sposób:
    Istniejący kod 1

    ...CustVendLedgEntryCurrencyCode@1120069 : Code[10];
    PayRecAccount@1120070 : Code[20];

    // Delete the following line.
    PROCEDURE Init@1120084(StartingDateValue@1120095 : Date;EndingDateValue@1120085 : Date;IncludeOpeningBalancesValue@1120086 : Boolean;ReportFileNameValue@1120087 : Text[250]);

    BEGIN
    StartingDate := StartingDateValue;
    EndingDate := EndingDateValue;
    ...

    Kod zastępczy 1

    ...CustVendLedgEntryCurrencyCode@1120069 : Code[10];
    PayRecAccount@1120070 : Code[20];

    // Add the following line.
    PROCEDURE Init@1120084(StartingDateValue@1120095 : Date;EndingDateValue@1120085 : Date;IncludeOpeningBalancesValue@1120086 : Boolean;AccNoFilter@1120088 : Code[250];ReportFileNameValue@1120087 : Text[250]);

    BEGIN
    StartingDate := StartingDateValue;
    EndingDate := EndingDateValue;
    ...

    Istniejący kod 2

    ...StartingDate := StartingDateValue;
    EndingDate := EndingDateValue;
    IncludeOpeningBalances := IncludeOpeningBalancesValue;
    ReportFileName := ReportFileNameValue;
    END;
    ...

    Kod zastępczy 2

    ...StartingDate := StartingDateValue;
    EndingDate := EndingDateValue;
    IncludeOpeningBalances := IncludeOpeningBalancesValue;

    // Add the following line.
    GLAccNoFilter := AccNoFilter;

    ReportFileName := ReportFileNameValue;
    END;
    ...
  6. Zmień kod w funkcji GetTransPayRecEntriesCount w wyeksportować zapisy K/G - sprawozdanie z kontroli podatku (10885) w następujący sposób:
    Istniejący kod 1

    ...LOCAL PROCEDURE GetTransPayRecEntriesCount@1120029(TransactionNo@1120044 : Integer;PayRecAccount@1120000 : Code[20]) : Integer;
    VAR
    GLEntryCount@1120045 : Integer;

    // Delete the following line.
    BEGIN

    GLEntry.SETRANGE("G/L Account No.",PayRecAccount);
    GLEntry.SETRANGE("Transaction No.",TransactionNo);
    GLEntryCount := GLEntry.COUNT;
    ...

    Kod zastępczy 1

    ...LOCAL PROCEDURE GetTransPayRecEntriesCount@1120029(TransactionNo@1120044 : Integer;PayRecAccount@1120000 : Code[20]) : Integer;
    VAR
    GLEntryCount@1120045 : Integer;

    // Add the following lines.
    GLAccNoFilter@1120046 : Code[250];
    BEGIN
    GLAccNoFilter := GLEntry.GETFILTER("G/L Account No.");
    // End of the added lines.

    GLEntry.SETRANGE("G/L Account No.",PayRecAccount);
    GLEntry.SETRANGE("Transaction No.",TransactionNo);
    GLEntryCount := GLEntry.COUNT;
    ...

    Istniejący kod 2

    ...GLEntry.SETRANGE("Transaction No.",TransactionNo);
    GLEntryCount := GLEntry.COUNT;
    GLEntry.SETRANGE("Transaction No.");

    // Delete the following line.
    GLEntry.SETRANGE("G/L Account No.");

    EXIT(GLEntryCount)
    END;
    ...

    Kod zastępczy 2

    ...GLEntry.SETRANGE("Transaction No.",TransactionNo);
    GLEntryCount := GLEntry.COUNT;
    GLEntry.SETRANGE("Transaction No.");

    // Add the following line.
    GLEntry.SETFILTER("G/L Account No.",GLAccNoFilter);

    EXIT(GLEntryCount)
    END;
    ...


Wymagania wstępne

Musi mieć jedną z następujących produktów, w celu zastosowania tej poprawki:

  • Francuskiej wersji systemu Microsoft Dynamics NAV 2009 R2

  • W wersji francuskiej dla dodatku SP1 dla programu Microsoft Dynamics NAV 2009

Informacje dotyczące usuwania

Nie można usunąć tej poprawki.

Stan

Firma Microsoft potwierdziła, że jest to problem występujący w produktach firmy Microsoft wymienionych w sekcji „Dotyczy”.

Powiązane artykuły

VSFT DynamicsNAVSE: 359563

Uwaga Jest to artykuł " szybkiej publikacji" tworzony bezpośrednio przez organizację pomocy technicznej firmy Microsoft. Informacje zawarte w niniejszym dokumencie są dostarczane jako odpowiedź na pojawiające się problemy. W wyniku przyspieszonego udostępnienia, materiały te mogą zawierać błędy typograficzne i mogą być zmieniane w dowolnym czasie bez uprzedzenia. Zobacz Warunki użytkowaniadla innych względów.

Autor: avannini
Writer: v-six
Weryfikacja tech.: avannini
Editor:

Potrzebna dalsza pomoc?

Rozwijaj swoje umiejętności
Poznaj szkolenia
Uzyskuj nowe funkcje w pierwszej kolejności
Dołącz do niejawnych testerów firmy Microsoft

Czy te informacje były pomocne?

Dziękujemy za opinię!

Dziękujemy za opinię! Wygląda na to, że połączenie Cię z jednym z naszych agentów pomocy technicznej pakietu Office może być pomocne.

×