AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 30.12.2010, 02:34   #1  
plumbum is offline
plumbum
Участник
Соотечественники
 
182 / 86 (3) ++++
Регистрация: 07.12.2007
Адрес: Vienna, AT
Глобальная адресная книга. Нулевая ссылка в таблице Address
Доброго времени суток.
И снова глобальная адресная книга в студии!

Попробую зайти с фланга: существует настроенный справочник "глобальная адресная книга", расшареный на несколько компаний через вируальную. Необходимо создать адрес для конкретного клиента через форму CustTable. При этом, как известно, адрес будет связан с клиентом через ту же глобальную адресную книгу (DirPartyTable) следующим образом (вернее 2-мя):

X++:
...
Address.RecId  == DirPartyAddressRelationshipMapping.AddressRecId
Address.DataAreaId  == DirPartyAddressRelationshipMapping.RefCompanyId

DirPartyAddressRelationshipMapping.PartyAddressRelationshipRecId == DirPartyAddressRelationship.RecId

DirPartyAddressRelationship.PartyId == DirPartyTable.PartyId
...
или

X++:
...
Address.AddrTableId   == tableNum(DirPartyTable)
Address.AddrRecId      == DirPartyTable.RecId
...
создаем адрес через форму клиентов и тут выясняется, что ОООЧЕНЬ редко (никому из наших не удалось воспроизвести) вторая ссылка не заполняется. Как результат: адрес видно из глобальной адресной книги и не видно из клиента. (это связанно с тем, что запросы к таблице Address из 2-х форм по-разному строятся)

как вариант поставил такую заглушку в Address.insert(), Address.update()
X++:
if (this.isFormDataSource() && ! this.AddrTableId && ! this.AddrRecId)
    {
        if (this.<DirPartyAddressRelationship>().PartyId)
        {
            this.AddrTableId = tableNum(DirPartyTable);
            this.AddrRecId  = DirPartyTable::find(this<DirPartyAddressRelationship>().PartyId).RecId;
        }        
    }
(в угловых скобках метод, достающий связь)

Не встречалась ли кому такая бага? Если встречалась, то как лечили?
Заранее спасибо!

DAX 2009 RU5
__________________
http://www.axdevposts.blogspot.com
Пришел, уведел.... отойди, дай другому увидеть!
Старый 31.12.2010, 12:17   #2  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
А табличка Address у вас виртуальная ?
Теги
address, global address book

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Sample Design Patterns: Upgrade to Microsoft Dynamics AX 2009 and issues with the global address book Blog bot DAX Blogs 0 21.12.2010 11:11
Опять глобальная адресная книга Sada DAX: Программирование 5 09.11.2010 14:16
Глобальная адресная книга Andrux DAX: Функционал 1 27.10.2010 07:40
Правильно ли выбран PrimaryIndex для таблицы Address? Morpheus DAX: Программирование 3 01.08.2007 23:43
InventLocation.address() DreamCreator DAX: Программирование 4 06.07.2006 15:18

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 23:05.