Интрастат се отчита на правителството и трябва да показват транзакции (количество), които са направени между граници, което се разбира от датска фирма и от други страни. Това означава, че ако се докладва, че елемент се търгува например, Германия през януари, транзакцията трябва да при никакви обстоятелства бъдат включени в дневника на вътрешни за февруари.

Транзакцията трябва да бъде включена веднъж, въпреки че стойността на транзакцията е нагоре или надолу, тъй като артикул. В момента също месец, когато е регистриран артикул се създава нов ред Интрастат дневника.

Този проблем възниква в следните продукти:

  • Датска версия на Microsoft Dynamics NAV 2009 R2

  • Датска версия на Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)

Решение

Информация за актуалната корекция

Вече се предлага от Microsoft предоставя поддържана актуална корекция. Обаче е предназначена само за коригиране на описания в тази статия. Прилагайте корекцията само към системи, изпитващи този конкретен проблем. Възможно е провеждането на допълнителни тестове на тази актуална корекция. Следователно ако не сте силно засегнати от този проблем, препоръчваме да изчакате следващия сервизен пакет за Microsoft Dynamics NAV 2009 или следващата версия на Microsoft Dynamics NAV, който ще съдържа тази корекция.

Забележка: При специални случаи таксите, които са за свързани с поддръжката обаждания могат да бъдат отменени, ако специалист по техническа поддръжка за Microsoft Dynamics и свързани с тях продукти определя, че конкретна актуализация може да разреши проблема. Обичайните такси за поддръжката ще важат за допълнителни въпроси и проблеми, които не спадат към съответната актуализация.

Информация за инсталирането

Microsoft предоставя примери само за илюстративни цели без гаранция за определени цели. Това включва, но не е ограничено до, подразбиращи се гаранции за продаваемост или годност за определена цел. Тази статия се предполага, че сте запознати с демонстрирания език за програмиране и инструментите, които се използват за създаване и процедури за отстраняване на грешки. Инженерите на поддръжката на Microsoft могат да помогнат обяснение на функциите на конкретна процедура. Въпреки това те няма да модифицират тези примери с цел осигуряване на допълнителна функционалност или създаване на процедури за удовлетворение на конкретните ви изисквания.

Забележка: Преди да инсталирате тази актуална корекция, уверете се, че всички потребители на клиента на Microsoft Dynamics NAV са излезли от системата. Това включва и услуги на Microsoft Dynamics NAV приложение сървър (NAS). Трябва да бъде само клиент потребител, който е влязъл при прилагане на тази актуална корекция.

За прилагане на тази актуална корекция, трябва да имате лиценз разработчик.

Препоръчително е потребителският акаунт в прозореца влизания в Windows или в прозореца на БД присвояването на "Супер" ИД на роля. Ако потребителският акаунт не може да бъде възложена ИД на роля на "Супер", трябва да проверите, че потребителският акаунт има следните права:

  • Разрешение за промяна на обекта, ще се променя.

  • Разрешението за изпълнение за системата обект номер 5210 обект и системата обект ID 9015

    обект.

Забележка: Не трябва да имате права на съхранените данни, освен ако трябва да извършите възстановяване на данни.

Промени код

Забележка: Винаги тест код решава в управлявана среда преди да приложите корекциите производство компютри.

За да разрешите този проблем, изпълнете следните стъпки:

  1. Променяте отчета се записи (594) както следва:
    Съществуващ код 1

    ...IF IntrastatJnlLine2.FINDFIRST THEN
    CurrReport.SKIP;

    // Delete the following line.
    TestILE("Item Ledger Entry");
    // End of the deleted line.

    TotalInvoicedQty := 0;
    TotalAmt := 0;
    ...

    Замени код 1

    ...IF IntrastatJnlLine2.FINDFIRST THEN
    CurrReport.SKIP;

    // Add the following lines.
    IF NOT HasCrossedBorder("Item Ledger Entry") THEN
    CurrReport.SKIP;
    // End of the added lines.

    TotalInvoicedQty := 0;
    TotalAmt := 0;
    ...

    Съществуващ код 2

    ...IF "Country/Region".GET("Item Ledger Entry"."Country/Region Code") THEN
    IF "Country/Region"."EU Country/Region Code" = '' THEN
    CurrReport.SKIP;
    TestILE("Item Ledger Entry");

    InsertValueEntryLine;
    END;
    END;
    ...

    Замени код 2

    ...IF "Country/Region".GET("Item Ledger Entry"."Country/Region Code") THEN
    IF "Country/Region"."EU Country/Region Code" = '' THEN
    CurrReport.SKIP;

    // Add the following line.
    IF HasCrossedBorder("Item Ledger Entry") THEN
    // End of the added lines.

    CurrReport.SKIP;
    InsertValueEntryLine;
    END;
    END;
    ...
  2. Променяте функцията CheckILE в отчета се записи (594) както следва:
    Съществуващ код 1

    ...EXIT(AverageQty >= 0);
    END;

    // Delete the following line.
    LOCAL PROCEDURE CheckILE@4(CountryRegionCode@1000 : Code[20]);
    // End of the deleted line.

    VAR
    CountryRegion@1001 : Record 9;
    BEGIN
    ...

    Замени код 1

    ...EXIT(AverageQty >= 0);
    END;

    // Add the following line.
    LOCAL PROCEDURE CountryOfOrigin@4(CountryRegionCode@1000 : Code[20]) : Boolean;
    // End of the added line.

    VAR
    CountryRegion@1001 : Record 9;
    BEGIN
    ...

    Съществуващ код 2

    ...IF ("Item Ledger Entry"."Country/Region Code" IN [CompanyInfo."Country/Region Code",'']) =
    (CountryRegionCode IN [CompanyInfo."Country/Region Code",''])
    THEN

    // Delete the following line.
    CurrReport.SKIP;
    // End of the deleted line.

    IF CountryRegionCode <> '' THEN BEGIN
    CountryRegion.GET(CountryRegionCode);
    IF CountryRegion."Intrastat Code" = '' THEN
    ...

    Замени код 2

    ...IF ("Item Ledger Entry"."Country/Region Code" IN [CompanyInfo."Country/Region Code",'']) =
    (CountryRegionCode IN [CompanyInfo."Country/Region Code",''])
    THEN

    // Add the following line.
    EXIT(FALSE);
    // End of the added line.

    IF CountryRegionCode <> '' THEN BEGIN
    CountryRegion.GET(CountryRegionCode);
    IF CountryRegion."Intrastat Code" = '' THEN
    ...

    Съществуващ код 3

    ...IF CountryRegionCode <> '' THEN BEGIN
    CountryRegion.GET(CountryRegionCode);
    IF CountryRegion."Intrastat Code" = '' THEN

    // Delete the following lines.
    CurrReport.SKIP;
    END;
    END;
    // End of the deleted lines.

    PROCEDURE TestILE@5(ItemLedgEntry@1000 : Record 32);
    VAR
    ItemLedgEntry2@1003 : Record 32;
    Location@1002 : Record 14;
    ...

    Замени код 3

    ...IF CountryRegionCode <> '' THEN BEGIN
    CountryRegion.GET(CountryRegionCode);
    IF CountryRegion."Intrastat Code" = '' THEN

    // Add the following lines.
    EXIT(FALSE);
    END;
    EXIT(TRUE);
    END;
    // End of the added lines.

    PROCEDURE HasCrossedBorder@5(ItemLedgEntry@1000 : Record 32) : Boolean;
    VAR
    ItemLedgEntry2@1003 : Record 32;
    Location@1002 : Record 14;
    ...
  3. Променяте функцията TestILE в отчета се записи (594) както следва:
    Съществуващ код 1

    ...IF ("Country/Region Code" = CompanyInfo."Country/Region Code") OR
    ("Country/Region Code" = '')
    THEN

    // Delete the following line.
    CurrReport.SKIP;
    // End of the deleted line.

    IF "Applies-to Entry" = 0 THEN BEGIN
    ItemLedgEntry2.SETCURRENTKEY("Item No.","Posting Date");
    ItemLedgEntry2.SETRANGE("Item No.","Item No.");
    ...

    Замени код 1

    ...IF ("Country/Region Code" = CompanyInfo."Country/Region Code") OR
    ("Country/Region Code" = '')
    THEN

    // Add the following line.
    EXIT(FALSE);
    // End of the added line.

    IF "Applies-to Entry" = 0 THEN BEGIN
    ItemLedgEntry2.SETCURRENTKEY("Item No.","Posting Date");
    ItemLedgEntry2.SETRANGE("Item No.","Item No.");
    ...

    Съществуващ код 2

    ...IF (ItemLedgEntry2."Country/Region Code" <> CompanyInfo."Country/Region Code") AND
    (ItemLedgEntry2."Country/Region Code" <> '')
    THEN
    CurrReport.SKIP;
    END;
    "Entry Type" = "Entry Type"::Transfer:
    BEGIN
    ...

    Замени код 2

    ...IF (ItemLedgEntry2."Country/Region Code" <> CompanyInfo."Country/Region Code") AND
    (ItemLedgEntry2."Country/Region Code" <> '')
    THEN
    EXIT(FALSE);
    END;
    "Entry Type" = "Entry Type"::Transfer:
    BEGIN
    ...

    Съществуващ код 3

    ...IF ("Country/Region Code" = CompanyInfo."Country/Region Code") OR
    ("Country/Region Code" = '')
    THEN
    CurrReport.SKIP;
    IF "Transfer Order No." = '' THEN BEGIN
    Location.GET("Location Code");
    IF (Location."Country/Region Code" <> '') AND
    ...

    Замени код 3

    ...IF ("Country/Region Code" = CompanyInfo."Country/Region Code") OR
    ("Country/Region Code" = '')
    THEN
    EXIT(FALSE);
    IF "Transfer Order No." = '' THEN BEGIN
    Location.GET("Location Code");
    IF (Location."Country/Region Code" <> '') AND
    ...

    Съществуващ код 4

    ...IF (Location."Country/Region Code" <> '') AND
    (Location."Country/Region Code" <> CompanyInfo."Country/Region Code")
    THEN
    CurrReport.SKIP;
    END ELSE BEGIN
    ItemLedgEntry2.SETRANGE("Transfer Order No.","Transfer Order No.");
    ItemLedgEntry2.SETFILTER("Country/Region Code",'%1 | %2','',CompanyInfo."Country/Region Code");
    ...

    Замени код 4

    ...IF (Location."Country/Region Code" <> '') AND
    (Location."Country/Region Code" <> CompanyInfo."Country/Region Code")
    THEN
    EXIT(FALSE);
    END ELSE BEGIN
    ItemLedgEntry2.SETRANGE("Transfer Order No.","Transfer Order No.");
    ItemLedgEntry2.SETFILTER("Country/Region Code",'%1 | %2','',CompanyInfo."Country/Region Code");
    ...

    Съществуващ код 5

    ...Include := TRUE;
    UNTIL Include OR (ItemLedgEntry2.NEXT = 0);
    IF NOT Include THEN
    CurrReport.SKIP;
    END;
    END;
    "Location Code" <> '':
    ...

    Замени код 5

    ...Include := TRUE;
    UNTIL Include OR (ItemLedgEntry2.NEXT = 0);
    IF NOT Include THEN
    EXIT(FALSE);
    END;
    END;
    "Location Code" <> '':
    ...

    Съществуващ код 6

    ..."Location Code" <> '':
    BEGIN
    Location.GET("Location Code");
    CheckILE(Location."Country/Region Code");
    END;
    ELSE BEGIN
    IF "Entry Type" = "Entry Type"::Purchase THEN
    ...

    Замени код 6

    ..."Location Code" <> '':
    BEGIN
    Location.GET("Location Code");
    IF NOT CountryOfOrigin(Location."Country/Region Code") THEN
    EXIT(FALSE);
    END;
    ELSE BEGIN
    IF "Entry Type" = "Entry Type"::Purchase THEN
    ...

    Съществуващ код 7

    ...END;
    ELSE BEGIN
    IF "Entry Type" = "Entry Type"::Purchase THEN
    CheckILE(CompanyInfo."Ship-to Country/Region Code");
    IF "Entry Type" = "Entry Type"::Sale THEN
    CheckILE(CompanyInfo."Country/Region Code");
    END;
    END;
    END;
    ...

    Замени код 7

    ...END;
    ELSE BEGIN
    IF "Entry Type" = "Entry Type"::Purchase THEN
    IF NOT CountryOfOrigin(CompanyInfo."Ship-to Country/Region Code") THEN
    EXIT(FALSE);
    IF "Entry Type" = "Entry Type"::Sale THEN
    IF NOT CountryOfOrigin(CompanyInfo."Country/Region Code") THEN
    EXIT(FALSE);
    END;
    END;
    END;
    ...
  4. Променяте функцията HasCrossedBorder в отчета се записи (594) както следва:
    Съществуващ код

    ...END;
    END;
    END;
    END;
    ...

    Замени код

    ...END;
    END;
    END;
    EXIT(TRUE)
    END;

    PROCEDURE InsertValueEntryLine@6();...


Необходими условия:

Трябва да имате един от следните продукти, за да приложите тази спешна корекция:

  • Датска версия на Microsoft Dynamics NAV 2009 R2

  • Датска версия на Microsoft Dynamics NAV 2009 SP1

Информация за премахване

Не можете да премахнете тази актуална корекция.

Статус

Microsoft потвърждава, че това е проблем в продуктите на Microsoft, изброени в раздела "Отнася се за".

Забележка: Това е статия "Бърза публикация", създадени директно от организацията за поддръжка на Microsoft. Информацията тук се предоставя "както-е" в отговор на появили се проблеми. В резултат на скоростта на предоставянето му материалите могат да съдържат печатни грешки и могат да бъдат коригирани по всяко време без предизвестие. Вижте Условияза други съображения.

Нуждаете се от още помощ?

Разширете уменията си
Преглед на обучението
Получавайте първи новите функции
Присъединете се към Microsoft приобщени

Беше ли полезна тази информация?

Доколко сте доволни от качеството на езика?
Какво е повлияло на вашия потребителски опит?

Благодарим ви за обратната връзка!

×