Застосовується до
Dynamics NAV 2009

Причини

Після оновлення Microsoft Dynamics NAV-3,7 до Microsoft Dynamics NAV, 2009, Запасів оцінка - WIP звіт (5802), можуть продемонструвати неправильну кількість. Засобу оновлення було вказано значення запису поле очікувана вартість, опублікований до головної книги під час вартість не була розміщена Е/l., виконайте дії, описані в розділі зміни коду , щоб вирішити цю проблему. Ця проблема виникає в таких продуктів:

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 пакет оновлень 1 (SP1)

Вирішення

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

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

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

Корпорація Майкрософт надає приклади програмного коду тільки для ілюстрації, без гарантій – прямих або інших. Це включає, але не обмежується, будь-яких гарантій придатності до продажу та придатності для певної мети. У цій статті припускається, що ви знайомі з, що демонструє мову програмування та інструменти, які використовуються для створення та налагодження процедури. Співробітники служби підтримки корпорації Майкрософт можуть пояснити функціональні особливості кожної конкретної процедури. Проте вони не будуть змінювати приклади для реалізації додаткових можливостей або створювати процедури на вимогу окремих користувачів.Примітка. Перш ніж інсталювати це виправлення, переконайтеся, що всіх користувачів Microsoft Dynamics NAV-клієнт відключився системи. Це стосується, служби Microsoft Dynamics NAV Application Server (NAS). Ви повинні тільки клієнт користувача, який увійшов до системи, під час виконання цього виправлення.Щоб застосувати це виправлення, потрібно мати ліцензію для розробників.Корпорація Майкрософт рекомендує, що обліковий запис користувача Windows, вхід вікна або у вікні бази даних вхід призначити "Супер" роль ID. Якщо обліковий запис користувача не призначено роль ID "Супер", необхідно переконатися, що обліковий запис користувача, має такі дозволи:

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

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

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

Зміни коду

Примітка. Завжди тест код вирішення в середовищі контрольовані перед інсталяцією розглянутого виправлення виробництва комп'ютерів.Щоб вирішити цю проблему, таким чином змінити код UpdateValueEntry функції в оновлення Nav 2009 крок 2-codeunit (104048):

Наявний код 1

...ExpValueEntry."Sales Amount (Expected)" += "Sales Amount (Expected)";                      ExpValueEntry."Cost Amount (Expected) (ACY)" += "Cost Amount (Expected) (ACY)";// Delete the following lines.                     CASE TRUE OF                       (("Cost Posted to G/L" = 0) AND ("Cost Posted to G/L (ACY)" = 0) AND                        ItemLedgEntry."Completely Invoiced"):                         BEGIN                           "Expected Cost Posted to G/L" := "Cost Amount (Expected)";                           "Exp. Cost Posted to G/L (ACY)" := "Cost Amount (Expected) (ACY)";                           ExpValueEntry."Expected Cost Posted to G/L" -= "Expected Cost Posted to G/L";                           ExpValueEntry."Exp. Cost Posted to G/L (ACY)" -= "Exp. Cost Posted to G/L (ACY)";                         END;                       (("Cost Posted to G/L" = "Cost Amount (Expected)") AND                        ("Cost Posted to G/L (ACY)" = "Cost Amount (Expected) (ACY)")):                         BEGIN                          "Expected Cost Posted to G/L" := "Cost Amount (Expected)";                           "Exp. Cost Posted to G/L (ACY)" := "Cost Amount (Expected) (ACY)";                         END;                       ("Cost Posted to G/L" <> 0) OR ("Cost Posted to G/L (ACY)" <> 0):                         BEGIN                           "Expected Cost Posted to G/L" :=                             ROUND("Cost Amount (Expected)" * QtyFactor,GLSetup."Amount Rounding Precision");                           "Exp. Cost Posted to G/L (ACY)" :=                             ROUND("Cost Amount (Expected) (ACY)" * QtyFactor,Currency."Amount Rounding Precision");                           ExpValueEntry."Expected Cost Posted to G/L" -=                             ROUND("Expected Cost Posted to G/L",GLSetup."Amount Rounding Precision");                           ExpValueEntry."Exp. Cost Posted to G/L (ACY)" -=                             ROUND("Exp. Cost Posted to G/L (ACY)",Currency."Amount Rounding Precision");                         END;// End of the deleted lines.                      END;                      "Cost Posted to G/L" := 0;                      "Cost Posted to G/L (ACY)" := 0;...

Код на заміну 1

...ExpValueEntry."Sales Amount (Expected)" += "Sales Amount (Expected)";                      ExpValueEntry."Cost Amount (Expected) (ACY)" += "Cost Amount (Expected) (ACY)";// Add the following lines.                     IF InvtSetup."Expected Cost Posting to G/L" THEN                       CASE TRUE OF                         (("Cost Posted to G/L" = 0) AND ("Cost Posted to G/L (ACY)" = 0) AND                          ItemLedgEntry."Completely Invoiced"):                           BEGIN                             "Expected Cost Posted to G/L" := "Cost Amount (Expected)";                             "Exp. Cost Posted to G/L (ACY)" := "Cost Amount (Expected) (ACY)";                             ExpValueEntry."Expected Cost Posted to G/L" -= "Expected Cost Posted to G/L";                             ExpValueEntry."Exp. Cost Posted to G/L (ACY)" -= "Exp. Cost Posted to G/L (ACY)";                           END;                         (("Cost Posted to G/L" = "Cost Amount (Expected)") AND                          ("Cost Posted to G/L (ACY)" = "Cost Amount (Expected) (ACY)")):                           BEGIN                             "Expected Cost Posted to G/L" := "Cost Amount (Expected)";                             "Exp. Cost Posted to G/L (ACY)" := "Cost Amount (Expected) (ACY)";                           END;                         ("Cost Posted to G/L" <> 0) OR ("Cost Posted to G/L (ACY)" <> 0):                           BEGIN                             "Expected Cost Posted to G/L" :=                               ROUND("Cost Amount (Expected)" * QtyFactor,GLSetup."Amount Rounding Precision");                             "Exp. Cost Posted to G/L (ACY)" :=                               ROUND("Cost Amount (Expected) (ACY)" * QtyFactor,Currency."Amount Rounding Precision");                             ExpValueEntry."Expected Cost Posted to G/L" -=                               ROUND("Expected Cost Posted to G/L",GLSetup."Amount Rounding Precision");                             ExpValueEntry."Exp. Cost Posted to G/L (ACY)" -=                               ROUND("Exp. Cost Posted to G/L (ACY)",Currency."Amount Rounding Precision");                           END;// End of the added lines.                      END;                      "Cost Posted to G/L" := 0;                      "Cost Posted to G/L (ACY)" := 0;...

Наявний код 2

...TempDocValueEntry."Cost Amount (Expected) (ACY)" += "Cost Amount (Expected) (ACY)";                      TempDocValueEntry.MODIFY;// Delete the following lines.                     IF (ABS(ExpValueEntry."Expected Cost Posted to G/L") > ABS("Cost Amount (Expected)")) OR                        (ABS(ExpValueEntry."Exp. Cost Posted to G/L (ACY)") > ABS("Cost Amount (Expected) (ACY)"))                     THEN BEGIN                       "Expected Cost Posted to G/L" := "Cost Amount (Expected)";                       "Exp. Cost Posted to G/L (ACY)" := "Cost Amount (Expected) (ACY)";                       ExpValueEntry."Expected Cost Posted to G/L" -= "Cost Amount (Expected)";                       ExpValueEntry."Exp. Cost Posted to G/L (ACY)" -= "Cost Amount (Expected) (ACY)";                     END ELSE BEGIN                       "Expected Cost Posted to G/L" := ExpValueEntry."Expected Cost Posted to G/L";                       "Exp. Cost Posted to G/L (ACY)" := ExpValueEntry."Exp. Cost Posted to G/L (ACY)";                       ExpValueEntry."Expected Cost Posted to G/L" := 0;                       ExpValueEntry."Exp. Cost Posted to G/L (ACY)" := 0;                     END;                    // End of the deleted lines.                 END;END;                  UpdateCostToPostToGL(ValueEntry);
...

Код на заміну 2

...
 TempDocValueEntry."Cost Amount (Expected) (ACY)" += "Cost Amount (Expected) (ACY)";                      TempDocValueEntry.MODIFY;// Add the following lines.                     IF InvtSetup."Expected Cost Posting to G/L" THEN                       IF (ABS(ExpValueEntry."Expected Cost Posted to G/L") > ABS("Cost Amount (Expected)")) OR                          (ABS(ExpValueEntry."Exp. Cost Posted to G/L (ACY)") > ABS("Cost Amount (Expected) (ACY)"))                       THEN BEGIN                         "Expected Cost Posted to G/L" := "Cost Amount (Expected)";                         "Exp. Cost Posted to G/L (ACY)" := "Cost Amount (Expected) (ACY)";                         ExpValueEntry."Expected Cost Posted to G/L" -= "Cost Amount (Expected)";                         ExpValueEntry."Exp. Cost Posted to G/L (ACY)" -= "Cost Amount (Expected) (ACY)";                       END ELSE BEGIN                         "Expected Cost Posted to G/L" := ExpValueEntry."Expected Cost Posted to G/L";                         "Exp. Cost Posted to G/L (ACY)" := ExpValueEntry."Exp. Cost Posted to G/L (ACY)";                         ExpValueEntry."Expected Cost Posted to G/L" := 0;                         ExpValueEntry."Exp. Cost Posted to G/L (ACY)" := 0;                                           END;// End of the added lines.                   END;END;                  UpdateCostToPostToGL(ValueEntry);
...

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

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

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 року з пакетом оновлень 1

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

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

Стан

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

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

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

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

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