Перейти до основного
Підтримка
Вхід
Вхід за допомогою облікового запису Microsoft
Увійдіть або створіть обліковий запис.
Вітаємо,
Виберіть інший обліковий запис.
У вас є кілька облікових записів
Виберіть обліковий запис, за допомогою якого потрібно ввійти.

Ця стаття відноситься до Microsoft Dynamics NAV всі країни і всі мови.

Причини

Припустімо, що повторно застосувати записів елемент, який використовує метод Середня вартість за допомогою застосунку книги в Microsoft Dynamics NAV, 2009. Під час запуску, звіт запасів оцінки, кількість дорівнює нулю, а параметр не дорівнює нулю. Ця проблема виникає в таких продуктів:

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 пакет оновлень 1 для

Вирішення

Відомості про виправлення

Корпорація Майкрософт випустила підтримуване виправлення доступна. Однак, застосовувати лише для вирішення проблеми, описаної в цій статті. Він придатний лише для систем, які зазнають цієї конкретної проблеми. Те, що це виправлення може потребувати додаткового тестування. Таким чином, якщо ви не завдає значної, рекомендовано почекати до виходу чергового пакета оновлень Microsoft Dynamics NAV, 2009 або наступної версії Microsoft Dynamics NAV, що містить це виправлення.

Примітка. В окремих випадках оплату звернення до служби підтримки може бути скасовано якщо технічної підтримки професійного для Microsoft Dynamics і пов'язані продукти визначає телефонів служби. Плата стягується на додаткові питання і проблеми, які не пов'язані з оновленням.


Відомості про інсталяцію

Корпорація Майкрософт надає приклади програмного коду тільки для ілюстрації, без гарантій – прямих або інших. Це включає, але не обмежується, будь-яких гарантій придатності до продажу та придатності для певної мети. У цій статті припускається, що ви знайомі з, що демонструє мову програмування та інструменти, які використовуються для створення та налагодження процедури. Співробітники служби підтримки корпорації Майкрософт можуть пояснити функціональні особливості кожної конкретної процедури. Проте вони не будуть змінювати приклади для реалізації додаткових можливостей або створювати процедури на вимогу окремих користувачів.

Примітка. Перш ніж інсталювати це виправлення, переконайтеся, що усі користувачі Microsoft Navision-клієнт відключився системи. Пакет оновлень містить служб Microsoft Navision застосунків (NAS) клієнта користувачів. Ви повинні тільки клієнт користувача, який увійшов до системи, під час виконання цього виправлення.

Щоб застосувати це виправлення, потрібно мати ліцензію для розробників.

Корпорація Майкрософт рекомендує, що обліковий запис користувача Windows, вхід вікна або у вікні бази даних вхід призначити "Супер" роль ID. Якщо обліковий запис користувача не призначено роль ID "Супер", необхідно переконатися, що обліковий запис користувача, має такі дозволи:

  • Змінити дозвіл об'єкт, який буде змінити.

  • Права для виконання системи об'єкт з Ідентифікатором 5210 об'єкт а також системи об'єкт з Ідентифікатором 9015 об'єкта.



Примітка. Маєте відповідних прав у сховища даних, якщо не потрібно виконати дані відновлення не потрібно.

Зміни коду

Примітка. Завжди тест код вирішення в середовищі контрольовані перед інсталяцією розглянутого виправлення виробництва комп'ютерів.
Щоб вирішити цю проблему, виконайте такі дії.

  1. Додати новий параметр FixedApplication -логічний вираз функції SetValuationDateAllValueEntrie елемента Jnl.-повідомлення рядка codeunit (22), як описано нижче:

    PROCEDURE SetValuationDateAllValueEntrie@95(ItemLedgerEntryNo@1000 : Integer;ValuationDate@1001 : Date;FixedApplication@1003 : Boolean);
  2. Змінити код функції SetValuationDateAllValueEntrie елемента Jnl.-повідомлення рядка codeunit (22), як описано нижче:
    Наявний код

    ...        IF FINDSET THEN
    REPEAT
    IF ("Valuation Date" <> "Posting Date") OR

    // Delete the following line.
    ("Valuation Date" < ValuationDate)

    THEN BEGIN
    "Valuation Date" := ValuationDate;
    MODIFY;
    END;
    UNTIL NEXT = 0;
    ...

    Заміна код

    ...        IF FINDSET THEN
    REPEAT
    IF ("Valuation Date" <> "Posting Date") OR

    // Add the following lines.
    ("Valuation Date" < ValuationDate) OR // Add an OR in this condition.
    (("Valuation Date" > ValuationDate) AND FixedApplication) // Add a new condition.
    // End of the lines.

    THEN BEGIN
    "Valuation Date" := ValuationDate;
    MODIFY;
    END;
    UNTIL NEXT = 0;
    ...

  3. Змінити код, значок відхилити застосування функції Jnl елемента.-codeunit повідомлення рядка (22), як описано нижче:
    Наявний код

    ...// Delete the following line.
    SetValuationDateAllValueEntrie(CostItemLedgEntry."Entry No.",Valuationdate);
    ...

    Заміна код

    ...// Add the following line.
    SetValuationDateAllValueEntrie(CostItemLedgEntry."Entry No.",Valuationdate,FALSE);
    ...

  4. Змінити код функції CostApply елемента Jnl.-повідомлення рядка codeunit (22), як описано нижче:
    Наявний код

    ...// Delete the following line.
    SetValuationDateAllValueEntrie(GlobalItemLedgEntry."Entry No.",ValueEntry."Valuation Date");
    ...

    Заміна код

    ...// Add the following line.
    SetValuationDateAllValueEntrie(GlobalItemLedgEntry."Entry No.",ValueEntry."Valuation Date",FALSE);
    ...

  5. Змінити код функції GetValuationDate елемента Jnl.-повідомлення рядка codeunit (22), як описано нижче:
    Наявний код

    ...        IF Positive THEN BEGIN
    IF (ValueEntry."Posting Date" < OldValueEntry."Valuation Date") OR
    (ItemJnlLine."Applies-to Entry" <> 0)

    // Delete the following lines.
    THEN BEGIN
    ValueEntry."Valuation Date" := OldValueEntry."Valuation Date";
    SetValuationDateAllValueEntrie(ValueEntry."Item Ledger Entry No.",OldValueEntry."Valuation Date");
    END ELSE
    BEGIN
    ValueEntry."Valuation Date" := ValueEntry."Posting Date";
    SetValuationDateAllValueEntrie(ValueEntry."Item Ledger Entry No.",ValueEntry."Posting Date");
    END
    // End of the lines.
    ...

    Заміна код

    ...        IF Positive THEN BEGIN
    IF (ValueEntry."Posting Date" < OldValueEntry."Valuation Date") OR
    (ItemJnlLine."Applies-to Entry" <> 0)

    // Add the following lines.
    THEN BEGIN
    ValueEntry."Valuation Date" := OldValueEntry."Valuation Date";
    SetValuationDateAllValueEntrie(
    ValueEntry."Item Ledger Entry No.",
    OldValueEntry."Valuation Date",
    ItemJnlLine."Applies-to Entry" <> 0)
    END ELSE BEGIN
    ValueEntry."Valuation Date" := ValueEntry."Posting Date";
    SetValuationDateAllValueEntrie(
    ValueEntry."Item Ledger Entry No.",
    ValueEntry."Posting Date",
    ItemJnlLine."Applies-to Entry" <> 0)
    END
    // End of the lines.
    ...

Попередні вимоги

Ви повинні мати одну з таких продуктів, щоб застосувати це виправлення:

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 пакет оновлень 1 для

Відомості про видалення

Це виправлення не можна видалити.

Стан

Корпорація Майкрософт підтвердила існування цієї неполадки у продуктах Майкрософт, перелічених у розділі "Застосовується до".

Примітка. Це "Швидка публікація" статті, надана службою підтримки корпорації Майкрософт. Відомості в цій статті надано без змін у відповідь на повідомлення про проблеми. З огляду на швидкість публікації матеріали можуть містити орфографічні помилки. Їх може бути змінено в будь-який час без повідомлення. Щоб отримати додаткові відомості, див. Умови використання.

Потрібна додаткова довідка?

Потрібні додаткові параметри?

Ознайомтеся з перевагами передплати, перегляньте навчальні курси, дізнайтесь, як захистити свій пристрій тощо.

Спільноти допомагають ставити запитання й відповідати на них, надавати відгуки та дізнаватися думки висококваліфікованих експертів.

Чи ця інформація була корисною?

Наскільки ви задоволені якістю мови?
Що вплинуло на ваші враження?
Натиснувши кнопку "Надіслати", ви надасте свій відгук для покращення продуктів і служб Microsoft. Ваш ІТ-адміністратор зможе збирати ці дані. Декларація про конфіденційність.

Дякуємо за відгук!

×