Указано неверное значение в поле «Сумма остатка» в операции, которая создается для счета, несмотря на то, что исправление 975264 в Microsoft Dynamics NAV 2009


Данная статья относится к Microsoft Dynamics NAV для всех стран и всех языковых стандартов.

Симптомы


Рассмотрим следующий сценарий в Microsoft Dynamics NAV 2009:
  • Установите исправление 975264.
    Дополнительные сведения об исправлении 975264 щелкните следующий номер статьи базы знаний Майкрософт:
    975264 значение в поле «Сумма остатка» в операции, которая создается для оплаты неверен в Microsoft Dynamics NAV
  • Введите значение в Примен. Точность округления на вкладке приложения в окне Финансы Настройка .
  • Разноска накладной по продаже.
  • Учет журнала оплат для счета продажи.
В этом случае указано неверное значение в поле Сумма остатка соответствующей учтенной операции. Значение не должно отображаться в поле Сумма остатка .
Эта проблема возникает в следующих продуктах:
  • Microsoft Dynamics NAV 2009 R2
  • Microsoft Dynamics NAV 2009 Пакет обновления 1 (SP1)

Решение


Сведения об исправлении

Исправление от корпорации Майкрософт доступно. Однако оно предназначено только для устранения проблемы, описанной в этой статье. Предлагаемое исправление должно применяться исключительно в системах, в которых обнаружена эта специфическая неполадка. Это исправление может проходить дополнительное тестирование. Таким образом Если вы не подвержены серьезно эту проблему, рекомендуется дождаться следующего пакета обновления для Microsoft Dynamics NAV или следующей версии Microsoft Dynamics NAV, содержащего это исправление.

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


Сведения об установке

Корпорация Майкрософт предлагает примеры программного кода только для иллюстрации и без явных или подразумеваемых гарантий. Это включает, но не ограничиваясь, подразумеваемые гарантии товарной пригодности или пригодности для определенной цели. В данной статье предполагается, что вы знакомы с демонстрируемым языком программирования и средствами, которые используются для создания и отладки. Сотрудники службы поддержки Майкрософт могут объяснить возможности конкретной процедуры, но не выполнять модификации примеров для обеспечения дополнительных функциональных возможностей или создания процедур для определенных требований.

Примечание. Перед установкой данного исправления убедитесь, что все пользователи Microsoft Navision вошли выход из системы. Это включает в себя пользователей клиентских служб приложений Microsoft Navision (NAS). Должен быть только клиент пользователя, который вошел в систему, при реализации данного исправления.

Чтобы реализовать это исправление, необходимо иметь лицензию разработчика.

Рекомендуется, чтобы учетной записи пользователя в окне Логины Windows или в окне Логины базы данных был присвоен идентификатор роли «SUPER» Если учетная запись пользователя не может быть назначена роль «SUPER» идентификатор, необходимо убедиться, что учетная запись пользователя имеет следующие разрешения.
  • Изменение разрешений для объекта, подлежащий изменению.
  • Разрешение Execute для объекта идентификатор объекта системы 5210 и 9015 идентификатор объекта системного объекта.


Примечание. Необходимо иметь права к хранилищам данных, если необходимо выполнить восстановление данных.

Изменения кода

Примечание. Всегда тестовый код исправления в контролируемой среде, прежде чем применить исправления на производственных компьютерах.
Чтобы устранить эту проблему, выполните следующие действия:
  1. Изменение кода в триггере PostCust в общий журнал.-программный блок учет строки (12), как показано ниже:
    Существующий код
    ...// Post the application
    ApplyCustLedgEntry(

    // Delete the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine,GLSetup."Appln. Rounding Precision");

    // Post customer entry
    ...
    Код для замены
    ...// Post the application
    ApplyCustLedgEntry(

    // Add the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine);

    // Post customer entry
    ...
  2. Изменение кода в триггере PostVend в общий журнал.-программный блок учет строки (12), как показано ниже:
    Существующий код
    ...// Post the application
    ApplyVendLedgEntry(

    // Delete the following lines.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine,
    GLSetup."Appln. Rounding Precision");
    // End of the lines.

    // Post Vendor entry
    ...
    Код для замены
    ...// Post the application
    ApplyVendLedgEntry(

    // Add the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine);

    // Post Vendor entry
    ...
  3. Добавить новый локальный параметр в функции ApplyCustLedgEntry в общий журнал.-учет строки функции (12), а затем укажите параметр следующим образом:
    • Var: No
    • Имя: ApplnRoundingPrecision
    • Тип данных: десятичное
  4. Добавьте новую локальную переменную в функции ApplyCustLedgEntry в общий журнал.-учет строки функции (12), а затем укажите переменную следующим образом:
    • Имя: ApplnRoundingPrecision
    • Тип данных: десятичное
  5. Измените код в функцию ApplyCustLedgEntry в общий журнал.-программный блок учет строки (12), как показано ниже:
    Существующий код 1
    ...NewCVLedgEntryBuf2 := NewCVLedgEntryBuf;

    // Delete the following lines.
    IF NewCVLedgEntryBuf."Currency Code" <> '' THEN BEGIN
    Management of application of already posted entries
    IF NewCVLedgEntryBuf."Currency Code" <> ApplnCurrency.Code THEN
    ApplnCurrency.GET(NewCVLedgEntryBuf."Currency Code");
    ApplnRoundingPrecision := ApplnCurrency."Appln. Rounding Precision";
    END ELSE
    ApplnRoundingPrecision := GLSetup."Appln. Rounding Precision";
    // End of the lines.

    ApplyingDate := GenJnlLine."Posting Date";

    IF GenJnlLine."Applies-to Doc. No." <> '' THEN BEGIN
    ...
    Код для замены 1
    ...NewCVLedgEntryBuf2 := NewCVLedgEntryBuf;

    ApplyingDate := GenJnlLine."Posting Date";

    IF GenJnlLine."Applies-to Doc. No." <> '' THEN BEGIN
    ...
    Существующий код 2
    ...// Management of posting in multiple currencies
    OldCVLedgEntryBuf2 := OldCVLedgEntryBuf;
    OldCVLedgEntryBuf.COPYFILTER(Positive,OldCVLedgEntryBuf2.Positive);

    IF NewCVLedgEntryBuf."Currency Code" <> OldCVLedgEntryBuf2."Currency Code" THEN BEGIN

    ...
    Код для замены 2
    ...// Management of posting in multiple currencies
    OldCVLedgEntryBuf2 := OldCVLedgEntryBuf;
    OldCVLedgEntryBuf.COPYFILTER(Positive,OldCVLedgEntryBuf2.Positive);

    // Add the following line.
    GetApplnRoundPrecision(ApplnRoundingPrecision,NewCVLedgEntryBuf,OldCVLedgEntryBuf);

    IF NewCVLedgEntryBuf."Currency Code" <> OldCVLedgEntryBuf2."Currency Code" THEN BEGIN
    ...
  6. Измените код в функцию CustPostApplyCustLedgEntry в общий журнал.-программный блок учет строки (12), как показано ниже:
    Существующий код
    ...// Post the application
    CustLedgEntry.CALCFIELDS(
    Amount,"Amount (LCY)","Remaining Amount","Remaining Amt. (LCY)",
    "Original Amount","Original Amt. (LCY)");
    TransferCustLedgEntry(CVLedgEntryBuf,CustLedgEntry,TRUE);
    ApplyCustLedgEntry(

    // Delete the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine,GLSetup."Appln. Rounding Precision");

    TransferCustLedgEntry(CVLedgEntryBuf,CustLedgEntry,FALSE);
    CustLedgEntry.MODIFY;
    ...
    Код для замены
    ...// Post the application
    CustLedgEntry.CALCFIELDS(
    Amount,"Amount (LCY)","Remaining Amount","Remaining Amt. (LCY)",
    "Original Amount","Original Amt. (LCY)");
    TransferCustLedgEntry(CVLedgEntryBuf,CustLedgEntry,TRUE);
    ApplyCustLedgEntry(

    // Add the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine);

    TransferCustLedgEntry(CVLedgEntryBuf,CustLedgEntry,FALSE);
    CustLedgEntry.MODIFY;
    ...
  7. Добавить новый локальный параметр в функции ApplyVendLedgEntry в общий журнал.-учет строки функции (12), а затем укажите параметр следующим образом:
    • Var: No
    • Имя: ApplnRoundingPrecision
    • Тип данных: десятичное
  8. Добавьте новую локальную переменную в функции ApplyVendLedgEntry в общий журнал.-учет строки функции (12), а затем укажите переменную следующим образом:
    • Имя: ApplnRoundingPrecision
    • Тип данных: десятичное
  9. Измените код в функцию ApplyVendLedgEntry в общий журнал.-программный блок учет строки (12), как показано ниже:
    Существующий код 1
    ...NewCVLedgEntryBuf2 := NewCVLedgEntryBuf;

    // Delete the following lines.
    IF NewCVLedgEntryBuf."Currency Code" <> '' THEN BEGIN
    // Management of application of already posted entries
    IF NewCVLedgEntryBuf."Currency Code" <> ApplnCurrency.Code THEN
    ApplnCurrency.GET(NewCVLedgEntryBuf."Currency Code");
    ApplnRoundingPrecision := ApplnCurrency."Appln. Rounding Precision";
    END ELSE
    ApplnRoundingPrecision := GLSetup."Appln. Rounding Precision";
    // End of the lines.

    ApplyingDate := GenJnlLine."Posting Date";

    IF GenJnlLine."Applies-to Doc. No." <> '' THEN BEGIN
    ...
    Код для замены 1
    ...NewCVLedgEntryBuf2 := NewCVLedgEntryBuf;

    ApplyingDate := GenJnlLine."Posting Date";

    IF GenJnlLine."Applies-to Doc. No." <> '' THEN BEGIN
    ...
    Существующий код 2
    ...// Management of posting in multiple currencies
    OldCVLedgEntryBuf2 := OldCVLedgEntryBuf;
    OldCVLedgEntryBuf.COPYFILTER(Positive,OldCVLedgEntryBuf2.Positive);

    IF NewCVLedgEntryBuf."Currency Code" <> OldCVLedgEntryBuf2."Currency Code" THEN BEGIN
    ...
    Код для замены 2
    ...// Management of posting in multiple currencies
    OldCVLedgEntryBuf2 := OldCVLedgEntryBuf;
    OldCVLedgEntryBuf.COPYFILTER(Positive,OldCVLedgEntryBuf2.Positive);

    // Add the following line.
    GetApplnRoundPrecision(ApplnRoundingPrecision,NewCVLedgEntryBuf,OldCVLedgEntryBuf);

    IF NewCVLedgEntryBuf."Currency Code" <> OldCVLedgEntryBuf2."Currency Code" THEN BEGIN
    ...
  10. Измените код в функцию VendPostApplyVendLedgEntry в общий журнал.-программный блок учет строки (12), как показано ниже:
    Существующий код
    ...// Post the application
    VendLedgEntry.CALCFIELDS(
    Amount,"Amount (LCY)","Remaining Amount","Remaining Amt. (LCY)",
    "Original Amount","Original Amt. (LCY)");
    TransferVendLedgEntry(CVLedgEntryBuf,VendLedgEntry,TRUE);
    ApplyVendLedgEntry(

    // Delete the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine,GLSetup."Appln. Rounding Precision");

    TransferVendLedgEntry(CVLedgEntryBuf,VendLedgEntry,FALSE);
    ...
    Код для замены
    ...// Post the application
    VendLedgEntry.CALCFIELDS(
    Amount,"Amount (LCY)","Remaining Amount","Remaining Amt. (LCY)",
    "Original Amount","Original Amt. (LCY)");
    TransferVendLedgEntry(CVLedgEntryBuf,VendLedgEntry,TRUE);
    ApplyVendLedgEntry(

    // Add the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine);

    TransferVendLedgEntry(CVLedgEntryBuf,VendLedgEntry,FALSE);
    ...
  11. Создание новой функцией GetApplnRoundPrecision в журнал Фин.-учет строки функции (12). Чтобы создать функцию, выполните следующие действия:
    1. Добавить новый локальный параметр в функцией GetApplnRoundPrecision в журнал Фин.-учет строки функции (12), а затем укажите параметр следующим образом:
      • Var: Да
      • Имя: ApplnRoundingPrecision
      • Тип данных: десятичное
    2. Добавить новый локальный параметр в функцией GetApplnRoundPrecision в журнал Фин.-учет строки функции (12), а затем укажите параметр следующим образом:
      • Var: No
      • Имя: NewCVLedgEntryBuf
      • Тип данных: записи
      • Подтип: КП Книга операций буфер
    3. Добавить новый локальный параметр в функцией GetApplnRoundPrecision в журнал Фин.-учет строки функции (12), а затем укажите параметр следующим образом:
      • Var: No
      • Имя: OldCVLedgEntryBuf
      • Тип данных: записи
      • Подтип: КП Книга операций буфер
    4. Добавить новую локальную переменную в функцией GetApplnRoundPrecision в журнал Фин.-учет строки функции (12), а затем укажите переменную следующим образом:
      • Имя: CurrencyExistInledger
      • Тип данных: логические
    5. Добавить новую локальную переменную в функцией GetApplnRoundPrecision в журнал Фин.-учет строки функции (12), а затем укажите переменную следующим образом:
      • Имя: CurrencyCode
      • Тип данных: код
      • Длина: 20
    6. Добавьте следующий код в функцией GetApplnRoundPrecision в журнал Фин.-учет строки функции (12):
      IF NewCVLedgEntryBuf."Currency Code" <> '' THENCurrencyCode := NewCVLedgEntryBuf."Currency Code"
      ELSE
      CurrencyCode := OldCVLedgEntryBuf."Currency Code";
      IF CurrencyCode <> ApplnCurrency.Code THEN
      CurrencyExistInledger := ApplnCurrency.GET(CurrencyCode);

      IF CurrencyExistInledger THEN BEGIN
      IF ApplnCurrency."Appln. Rounding Precision" <> 0 THEN
      ApplnRoundingPrecision := ApplnCurrency."Appln. Rounding Precision"
      ELSE
      ApplnRoundingPrecision := GLSetup."Appln. Rounding Precision";
      END;

Предварительные условия

Необходимы следующие продукты для установки данного исправления.
  • Microsoft Dynamics NAV 2009 R2
  • Microsoft Dynamics NAV 2009 Пакет обновления 1 (SP1)

Сведения об удалении

Установленное обновление удалить нельзя.

Статус


Корпорация Майкрософт подтверждает, что это проблема продуктов Майкрософт, перечисленных в разделе "Относится к".
Примечание. Это статья «БЫСТРАЯ ПУБЛИКАЦИЯ», созданная непосредственно из технической поддержки корпорации Майкрософт. Сведения, содержащиеся в настоящем документе, предоставляются "как есть" в ответ на возникающие проблемы. В результате скорости предоставления материалов они могут включать опечаток и быть изменены в любое время без предварительного уведомления. Другие вопросы, связанные с Условиями использования см.