Операции книги поставщика день (клиент) отчет (отчет 10535 & отчет 10525) не работает с более поздней версии приложения в Великобритании версии Microsoft Dynamics NAV 2009 R2 и в Великобритании версии Microsoft Dynamics NAV 2009 SP1


Данная статья относится к Microsoft Dynamics NAV для английского языка (Великобритания) (en-gb) региона.

Симптомы


В версии Microsoft Dynamics NAV 2009 R2 Великобритании или в Великобритании версии Microsoft Dynamics NAV 2009 Пакет обновления 1 (SP1) предполагается сделать приложения для применения журнала к счету после учета журналов для поставщика или клиента. Затем при выполнении Операции книги поставщика день (клиент) (отчет отчет 10535/10525), отчет распечатывается неправильно связанных финансовых операций.

Причина


Отчет извлекает финансовые операции, номер транзакции, но когда приложение выполняется позже, полученного прибылям/убыткам операций разносятся на другой транзакции.

Решение


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

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

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



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

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

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

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

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


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

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

Примечание. Всегда тестовый код исправления в контролируемой среде, прежде чем применить исправления на производственных компьютерах.
Чтобы устранить эту проблему, выполните следующие действия:
  1. Измените код в триггере Финансовая операция - OnPreDataItem в отчете День книги поставщиков клиентской операции (10525) следующим образом:
    В меню Вид добавьте следующие переменные на вкладке переменные в C/AL локальные переменные:
    • Имя: DtldCustLedgEntry; Тип данных: Запись; Подтип: Подроб. Номер операции книги. Запись
    • Имя: TransactionNoFilter; Тип данных: Текст; Длина: 250

    Существующий код
    ...  IF NOT PrintGLDetails THEN
    // Delete the following line.
    CurrReport.BREAK;
    ...
    Код для замены
    ...IF NOT PrintGLDetails THEN
    // Add the following lines.
    CurrReport.BREAK
    ELSE BEGIN
    // End of the added lines.
    ...

    Финансовая операция < финансовой операции > DataItem, в меню Вид выберите, нажмите кнопку занося, выберите DataItemLink и удаление по следующей ссылке: номер транзакции = ПОЛЕ (номер транзакции)
  2. Измените код в триггере Финансовая операция - OnPreDataItem в отчете День книги поставщиков клиентской операции (10535) следующим образом:
    В меню Вид добавьте следующие переменные на вкладке переменные в C/AL локальные переменные:
    • Имя: DtldVendLedgEntry; Тип данных: Запись; Подтип: Подроб. Запись
    • Имя: TransactionNoFilter; Тип данных: Текст; Длина: 250

    Существующий код
    ...  IF NOT PrintGLDetails THEN
    // Delete the following line.
    CurrReport.BREAK;
    ...
    Код для замены
    ...IF NOT PrintGLDetails THEN

    // Add the following lines.
    CurrReport.BREAK
    ELSE BEGIN
    DtldVendLedgEntry.RESET;
    DtldVendLedgEntry.SETRANGE("Vendor Ledger Entry No.","Vendor Ledger Entry"."Entry No.");
    DtldVendLedgEntry.SETFILTER("Entry Type",'<>%1',DtldVendLedgEntry."Entry Type"::Application);
    IF DtldVendLedgEntry.FINDSET THEN BEGIN
    TransactionNoFilter := FORMAT(DtldVendLedgEntry."Transaction No.");
    WHILE DtldVendLedgEntry.NEXT <>0 DO
    TransactionNoFilter := TransactionNoFilter + '|' + FORMAT(DtldVendLedgEntry."Transaction No.");
    END;
    SETFILTER("Transaction No.",TransactionNoFilter);
    END;
    DtldCustLedgEntry.RESET;
    DtldCustLedgEntry.SETRANGE("Cust. Ledger Entry No.","Cust. Ledger Entry"."Entry No.");
    DtldCustLedgEntry.SETFILTER("Entry Type",'<>%1',DtldCustLedgEntry."Entry Type"::Application);
    IF DtldCustLedgEntry.FINDSET THEN BEGIN
    TransactionNoFilter := FORMAT(DtldCustLedgEntry."Transaction No.");
    WHILE DtldCustLedgEntry.NEXT <>0 DO
    TransactionNoFilter := TransactionNoFilter + '|' + FORMAT(DtldCustLedgEntry."Transaction No.");
    END;
    SETFILTER("Transaction No.",TransactionNoFilter);
    END;
    // End of the added lines.
    ...

    Финансовая операция < финансовой операции > DataItem, в меню Вид выберите, нажмите кнопку занося, выберите DataItemLink и удаление по следующей ссылке: номер транзакции = ПОЛЕ (номер транзакции)

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

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


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

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

Статус


Корпорация Майкрософт подтверждает, что это проблема продуктов Майкрософт, перечисленных в разделе "Относится к".

Ссылки


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