Перейти к основному контенту
Поддержка
Войдите с помощью учетной записи Майкрософт
Войдите или создайте учетную запись.
Здравствуйте,
Выберите другую учетную запись.
У вас несколько учетных записей
Выберите учетную запись, с помощью которой нужно войти.

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

  • Английский (Канада) (en-ca)

  • Английский (США) (en-us)

  • Испанский (Мексика) (es-mx)

  • Французский (Канада) (fr-ca)

Симптомы

Предположим, что выполнять учет журнала оплат, использующего банковского счета иностранной валюты в северо-американской версии Microsoft Dynamics 2009. Создание корректировки для журнала оплат, запустив функцию Валюты Коррекция курсовых разниц... . В этом случае при создании банковской выверки банковского счета иностранной валюты, сальдо главной книги в строке предлагаемые рассчитывается неправильно. Расчет банковской выверки не включает реализованной прибыли или реализованному убытку банковского счета.
Эта проблема возникает в следующих продуктах:

  • Северо-американской версии Microsoft Dynamics NAV 2009 R2

  • Северо-американской версии Microsoft Dynamics NAV 2009 Пакет обновления 1 (SP1)

Решение

Важно! Восстановлен исходный код исправления (2548309) и должны быть удалены из базы данных, где это изменение было применено. При внесении изменений кода, описанные в разделе «Изменение кода», можно изменить код обратно так, что код соответствует обратно к разделу «Существующий код». Если код не возвращен, могут иметь различия на вкладке Общие банковской выверки и затем нельзя сделать запись.
Проблема с дисбаланс Финансы (финансовые) на Северной Америки выверки базы данных в исходном сценарии повторного создания для этой статьи был пересматривается и проверены. Посредством анализа разработки и управления продукта определить проблему, которая была обнаружена с дисбаланс не является результатом неправильного стандартный код для расчета банковской выверки, но данные проблему, которая возникает из-за первоначальной настройки банковского счета. Неправильная настройка начального банковского счета состоял из разрыва связи между операции банковского счета и операции финансового счета. Шаги настройки неправильные иностранной валюте банковского счета может содержать, напоминающее следующее:

  1. Учет финансового журнала для финансового счета банковского счета для начального сальдо финансового счета, например 11650.

    Примечание. Обычно эта проводка будет частью первоначальной настройки пробного баланса финансовых.

  2. Записи в дневнике поступления денежных средств на банковский счет, в котором учетная группа банковского счета имеет временный счет главной книги, например 11000 назначен, учет и всех открытых транзакций без согласования, как открыть чеки и денежные поступления на банковский счет. Балансирующий счет задается значение ту же учетную запись, например 11000, чтобы создать запись акция.

  3. Банковский счет учета учетная запись группы затем изменяется с временный счет ГК для финансового счета 11650. Таким образом исходной операции, которая была учтена для установления подробных банковский счет установки на шаге 2 был другой финансовый счет. Таким образом больше не установлена связь для финансовых операций.

Дополнительные неправильная настройка для банковского счета иностранной валюте будет выглядеть следующим образом:

  1. Учет финансового журнала для финансового счета банковского счета для начального сальдо финансового счета, например 11650.

  2. Затем финансовый журнал на банковский счет, с балансирующим счётом, задайте для одного финансового счета как указанное внутри учетная группа банковского счета, как в этом случае финансовый учет 11650.

Опять же нет нет связи между финансовой операции, учтенные в шаге 1 и Книга банковских операций, разнесенных в шаге 2.

Эти действия являются неправильный способ обработки начала нового иностранного банковского счета. При выполнении этого процесса неправильно, могут возникнуть проблемы, описанные в этой статье (2548309). Это исправление (2548309) было добавлено для исправления конкретного сценария, инициированной установки, аналогичное предыдущему сценарию. Тем не менее учета различных сценариев привела к проблемы, связанные с продолжением дисбаланс, если настроить банковский счет, а затем не хранить финансового счета в банке, учетная группа, или если отсутствует прямая связь между финансовых операций и операций по банковскому счету.

РЕКОМЕНДАЦИЯ: Рекомендуемый процесс настройки в иностранной валюте банк будет следующим образом (предполагается в локальной валюте для GL — 10 000 долларов США).

Примечание – ниже основывается на валютный курс 1:1. Финансовые суммы обновляются в местной валюте. Вычисления вручную необходимы для банковского счета, GL обновляется суммой правильных местной валюты.

  1. При разноске в ГК начало Пробные балансы, учесть сальдо ГК банка временные финансовые счета, как финансовые 11000 для 10 000 долларов США.

  2. Финансовый журнал на банковский счет, который имеет учетная группа банковского счета значение требуемого финансового счета в этот регистр финансовый учет 11650. Здесь будет установить Балансовый Счёт для финансового счета 11000, которая является начальной временные наличный счет, первоначально была учтена как часть установки начало пробного баланса.

    -Учет этой операции 10 000 обновит иностранного банковского счета и финансовый счет 11650 для 10 000 долларов США. Также уменьшается, временные счета 11000 $ 0 из-за смещения балансирующего счета из транзакции. Путем учета таким образом, нет прямой связи между банковские операции и операции финансового счета. Это правильный способ обработки и обрабатывать настройки иностранного банковского счета.


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

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

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



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

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

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

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

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

  • Изменение разрешений для объекта, подлежащий изменению.

  • Разрешение Execute для объекта идентификатор объекта системы 5210 и 9015 идентификатор объекта системного объекта.



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

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


Примечание. Всегда тестовый код исправления в контролируемой среде, прежде чем применить исправления на производственных компьютерах.
Чтобы устранить эту проблему, измените код в функцию CalculateBalance в таблице Банк получателя заголовка (10120) следующим образом:
Существующий код

...          REPEAT
IF BankAccLedgEntry.GET(GLEntry."Entry No.") THEN BEGIN
IF "Currency Code" <> BankAccLedgEntry."Currency Code" THEN BEGIN
IF BankAccLedgEntry."Currency Code" <> '' THEN
"G/L Balance" += ROUND(CurrExchRate.ExchangeAmtFCYToFCY("Statement Date",
BankAccLedgEntry."Currency Code",
"Currency Code",
BankAccLedgEntry.Amount),
Currency."Amount Rounding Precision")
ELSE
"G/L Balance" += ROUND(CurrExchRate.ExchangeAmtLCYToFCY("Statement Date",
"Currency Code",
BankAccLedgEntry.Amount,
"Currency Factor"),
Currency."Amount Rounding Precision");
END ELSE BEGIN

// Delete the folloiwng line.
"G/L Balance" += BankAccLedgEntry.Amount;

END;
END ELSE BEGIN
"G/L Balance" += ROUND(CurrExchRate.ExchangeAmtLCYToFCY("Statement Date",
"Currency Code",
GLEntry.Amount,
"Currency Factor"),
Currency."Amount Rounding Precision");
END;
UNTIL GLEntry.NEXT = 0;
...

Код для замены

...          REPEAT
IF BankAccLedgEntry.GET(GLEntry."Entry No.") THEN BEGIN
IF "Currency Code" <> BankAccLedgEntry."Currency Code" THEN BEGIN
IF BankAccLedgEntry."Currency Code" <> '' THEN
"G/L Balance" += ROUND(CurrExchRate.ExchangeAmtFCYToFCY("Statement Date",
BankAccLedgEntry."Currency Code",
"Currency Code",
BankAccLedgEntry.Amount),
Currency."Amount Rounding Precision")
ELSE
"G/L Balance" += ROUND(CurrExchRate.ExchangeAmtLCYToFCY("Statement Date",
"Currency Code",
BankAccLedgEntry.Amount,
"Currency Factor"),
Currency."Amount Rounding Precision");
END ELSE BEGIN

// Add the following lines.
"G/L Balance" += ROUND(CurrExchRate.ExchangeAmtLCYToFCY("Statement Date",
"Currency Code",
GLEntry.Amount,
"Currency Factor"),
Currency."Amount Rounding Precision");
// End of the lines.

END;
END ELSE BEGIN
"G/L Balance" += ROUND(CurrExchRate.ExchangeAmtLCYToFCY("Statement Date",
"Currency Code",
GLEntry.Amount,
"Currency Factor"),
Currency."Amount Rounding Precision");
END;
UNTIL GLEntry.NEXT = 0;
...


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

Необходимы следующие продукты для установки данного исправления.

  • Северо-американской версии Microsoft Dynamics NAV 2009 R2

  • Северо-американской версии Microsoft Dynamics NAV 2009 Пакет обновления 1

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

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

Статус

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

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

Нужна дополнительная помощь?

Нужны дополнительные параметры?

Изучите преимущества подписки, просмотрите учебные курсы, узнайте, как защитить свое устройство и т. д.

В сообществах можно задавать вопросы и отвечать на них, отправлять отзывы и консультироваться с экспертами разных профилей.

Были ли сведения полезными?

Насколько вы удовлетворены качеством перевода?
Что повлияло на вашу оценку?
После нажатия кнопки "Отправить" ваш отзыв будет использован для улучшения продуктов и служб Майкрософт. Эти данные будут доступны для сбора ИТ-администратору. Заявление о конфиденциальности.

Спасибо за ваш отзыв!

×