Ця стаття відноситься до Microsoft Dynamics NAV всі країни і всі мови.
Причини
Припустімо, що додається заплатити пакет для придбання документа в Microsoft Dynamics NAV, 2009. Після цього сума ПДВ придбання статистичні дані форм, або сторінку змінено. Під час відкриття статистичні дані форм, або сторінки знову, оновити значення.
Ця проблема виникає в таких продуктів:
-
Microsoft Dynamics NAV 2009 пакет оновлень 1 (SP1)
-
Microsoft Dynamics NAV 2009 R2
Вирішення
Відомості про виправлення
Корпорація Майкрософт випустила підтримуване виправлення доступна. Однак, застосовувати лише для вирішення проблеми, описаної в цій статті. Він придатний лише для систем, які зазнають цієї конкретної проблеми. Те, що це виправлення може потребувати додаткового тестування. Таким чином, якщо ви не завдає значної, рекомендовано почекати до виходу чергового пакета оновлень Microsoft Dynamics NAV, 2009 або наступної версії Microsoft Dynamics NAV, що містить це виправлення.
Примітка. В окремих випадках оплату звернення до служби підтримки може бути скасовано якщо технічної підтримки професійного для Microsoft Dynamics і пов'язані продукти визначає телефонів служби. Плата стягується на додаткові питання і проблеми, які не пов'язані з оновленням.
Відомості про інсталяцію
Корпорація Майкрософт надає приклади програмного коду тільки для ілюстрації, без гарантій – прямих або інших. Це включає, але не обмежується, будь-яких гарантій придатності до продажу та придатності для певної мети. У цій статті припускається, що ви знайомі з, що демонструє мову програмування та інструменти, які використовуються для створення та налагодження процедури. Співробітники служби підтримки корпорації Майкрософт можуть пояснити функціональні особливості кожної конкретної процедури, але вони не будуть змінювати приклади для реалізації додаткових можливостей або створювати процедури на вимогу окремих користувачів.
Примітка. Перш ніж інсталювати це виправлення, переконайтеся, що усі користувачі Microsoft Navision-клієнт відключився системи. Пакет оновлень містить служб Microsoft Navision застосунків (NAS) клієнта користувачів. Ви повинні тільки клієнт користувача, який увійшов до системи, під час виконання цього виправлення.
Щоб застосувати це виправлення, потрібно мати ліцензію для розробників.
Корпорація Майкрософт рекомендує, що обліковий запис користувача Windows, вхід вікна або у вікні бази даних вхід призначити "Супер" роль ID. Якщо обліковий запис користувача не призначено роль ID "Супер", необхідно переконатися, що обліковий запис користувача, має такі дозволи:
-
Змінити дозвіл об'єкт, який буде змінити.
-
Права для виконання системи об'єкт з Ідентифікатором 5210 об'єкт а також системи об'єкт з Ідентифікатором 9015 об'єкта.
Примітка. Маєте відповідних прав у сховища даних, якщо не потрібно виконати дані відновлення не потрібно.
Зміни коду
Примітка. Завжди тест код вирішення в середовищі контрольовані перед інсталяцією розглянутого виправлення виробництва комп'ютерів.
Щоб вирішити цю проблему, виконайте такі дії.
-
Змінити код UpdateVATAmounts функції продажу рядка таблиці (37) наступним чином:
Наявний код 1...END;
LOCAL PROCEDURE UpdateVATAmounts@38();
VAR
SalesLine2@1000 : Record 37;
TotalLineAmount@1005 : Decimal;
TotalInvDiscAmount@1004 : Decimal;
TotalAmount@1001 : Decimal;
TotalAmountInclVAT@1002 : Decimal;
TotalQuantityBase@1003 : Decimal;
...Код на заміну 1
...END;
LOCAL PROCEDURE UpdateVATAmounts@38();
VAR
SalesLine2@1000 : Record 37;
// Add the following line.
CustPostingGr@1009 : Record 92;
// End of the added line.
TotalLineAmount@1005 : Decimal;
TotalInvDiscAmount@1004 : Decimal;
TotalAmount@1001 : Decimal;
TotalAmountInclVAT@1002 : Decimal;
TotalQuantityBase@1003 : Decimal;
...Наявний код 2
...SalesLine2.SETFILTER(Amount,'>%1',0)
ELSE
SalesLine2.SETFILTER(Amount,'<%1',0);
SalesLine2.SETRANGE("VAT Identifier","VAT Identifier");
SalesLine2.SETRANGE("Tax Group Code","Tax Group Code");
IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
Amount := 0;
"VAT Base Amount" := 0;
"Amount Including VAT" := 0;
...Код на заміну 2
...SalesLine2.SETFILTER(Amount,'>%1',0)
ELSE
SalesLine2.SETFILTER(Amount,'<%1',0);
SalesLine2.SETRANGE("VAT Identifier","VAT Identifier");
SalesLine2.SETRANGE("Tax Group Code","Tax Group Code");
// Add the following line.
CustPostingGr.GET(SalesHeader."Customer Posting Group");
// End of the added line.
IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
Amount := 0;
"VAT Base Amount" := 0;
"Amount Including VAT" := 0;
...Наявний код 3
...IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
Amount := 0;
"VAT Base Amount" := 0;
"Amount Including VAT" := 0;
// Delete the following line.
IF "Line No." <> 0 THEN
// End of the deleted line.
IF MODIFY THEN
IF SalesLine2.FINDLAST THEN BEGIN
SalesLine2.UpdateAmounts;
SalesLine2.MODIFY;
END;
...Код на заміну 3
...IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
Amount := 0;
"VAT Base Amount" := 0;
"Amount Including VAT" := 0;
// Add the following line.
IF ("Line No." <> 0) AND NOT ((Type = Type::"G/L Account") AND ("No." = CustPostingGr."Service Charge Acc.")) THEN
// End of the added line.
IF MODIFY THEN
IF SalesLine2.FINDLAST THEN BEGIN
SalesLine2.UpdateAmounts;
SalesLine2.MODIFY;
END;
... -
Змінити код UpdateVATAmounts функції придбання рядка таблиці (39) наступним чином:
Наявний код 1...END;
LOCAL PROCEDURE UpdateVATAmounts@38();
VAR
PurchLine2@1000 : Record 39;
TotalLineAmount@1005 : Decimal;
TotalInvDiscAmount@1004 : Decimal;
TotalAmount@1001 : Decimal;
TotalAmountInclVAT@1002 : Decimal;
TotalQuantityBase@1003 : Decimal;
...Код на заміну 1
...END;
LOCAL PROCEDURE UpdateVATAmounts@38();
VAR
PurchLine2@1000 : Record 39;
// Add the following line.
VendPostingGr@1009 : Record 93;
// End of the added line.
TotalLineAmount@1005 : Decimal;
TotalInvDiscAmount@1004 : Decimal;
TotalAmount@1001 : Decimal;
TotalAmountInclVAT@1002 : Decimal;
TotalQuantityBase@1003 : Decimal;
...Наявний код 2
...PurchLine2.SETFILTER(Amount,'>%1',0)
ELSE
PurchLine2.SETFILTER(Amount,'<%1',0);
PurchLine2.SETRANGE("VAT Identifier","VAT Identifier");
PurchLine2.SETRANGE("Tax Group Code","Tax Group Code");
IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
Amount := 0;
"VAT Base Amount" := 0;
"Amount Including VAT" := 0;
...Код на заміну 2
...PurchLine2.SETFILTER(Amount,'>%1',0)
ELSE
PurchLine2.SETFILTER(Amount,'<%1',0);
PurchLine2.SETRANGE("VAT Identifier","VAT Identifier");
PurchLine2.SETRANGE("Tax Group Code","Tax Group Code");
// Add the following line.
VendPostingGr.GET(PurchHeader."Vendor Posting Group");
// End of the added line.
IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
Amount := 0;
"VAT Base Amount" := 0;
"Amount Including VAT" := 0;
...Наявний код 3
...IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
Amount := 0;
"VAT Base Amount" := 0;
"Amount Including VAT" := 0;
// Delete the following line.
IF "Line No." <> 0 THEN
// End of the deleted line.
IF MODIFY THEN
IF PurchLine2.FINDLAST THEN BEGIN
PurchLine2.UpdateAmounts;
PurchLine2.MODIFY;
END;
...Код на заміну 3
...IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
Amount := 0;
"VAT Base Amount" := 0;
"Amount Including VAT" := 0;
// Add the following line.
IF ("Line No." <> 0) AND NOT ((Type = Type::"G/L Account") AND ("No." = VendPostingGr."Service Charge Acc.")) THEN
// End of the added line.
IF MODIFY THEN
IF PurchLine2.FINDLAST THEN BEGIN
PurchLine2.UpdateAmounts;
PurchLine2.MODIFY;
END;
...
Попередні вимоги
Ви повинні мати одну з таких продуктів, щоб застосувати це виправлення:
-
Microsoft Dynamics NAV 2009 пакет оновлень 1 (SP1)
-
Microsoft Dynamics NAV 2009 R2
Відомості про видалення
Це виправлення не можна видалити.
Стан
Корпорація Майкрософт підтвердила існування цієї неполадки у продуктах Майкрософт, перелічених у розділі "Застосовується до".
Примітка. Це "Швидка публікація" статті, надана службою підтримки корпорації Майкрософт. Відомості в цій статті надано без змін у відповідь на повідомлення про проблеми. З огляду на швидкість публікації матеріали можуть містити орфографічні помилки. Їх може бути змінено в будь-який час без повідомлення. Щоб отримати додаткові відомості, див. Умови використання.