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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 12.02.2015, 22:11   #1  
kitty is offline
kitty
Участник
 
370 / 30 (2) +++
Регистрация: 24.05.2005
Required поле в схеме AIF документа
Две таблицы связаны по RecId (SurrogateKey: ChildTable.TableRefRecId = ParentTable.RecId). Есть соответствующий relation
TableRefRecId поле в ChildTable таблице обязательное (Mandatory = yes)

На основе этих двух таблиц создан запрос и соответвующий document service.

С чем связано, что, не смотря на то, что это surrogate key, в схеме документа автоматически для TableRefRecId проставляется required = yes (т.е minOccurs = 1) ?

AX2012 R2

Последний раз редактировалось kitty; 12.02.2015 в 22:19.
Старый 12.02.2015, 22:31   #2  
ax_mct is offline
ax_mct
Banned
 
2,548 / 1091 (0) ++++++++
Регистрация: 10.10.2005
Адрес: Westlands
Цитата:
Сообщение от kitty Посмотреть сообщение
Две таблицы связаны по RecId (SurrogateKey: ChildTable.TableRefRecId = ParentTable.RecId). Есть соответствующий relation
TableRefRecId поле в ChildTable таблице обязательное (Mandatory = yes)

На основе этих двух таблиц создан запрос и соответвующий document service.

С чем связано, что, не смотря на то, что это surrogate key, в схеме документа автоматически для TableRefRecId проставляется required = yes (т.е minOccurs = 1) ?

AX2012 R2
Как раз смотря на это. Почему другие ожидания для surrogate key?
Старый 12.02.2015, 23:28   #3  
kitty is offline
kitty
Участник
 
370 / 30 (2) +++
Регистрация: 24.05.2005
Не логично, тк при импорте документа , если TableRecid - required, то валидация документа провалится с ошибкой.
На момент импорта ParentTable.RecID вообще еще не существует (
присвоится только при вставке ParentTable записи в Ax и потом должно соответствующее значение автоматически присвоится childTable.TableRecId)

Причем, в prepareForSaveExtended есть соответсвующий код, присваивающий потомкам tableRecId родителя

Последний раз редактировалось kitty; 12.02.2015 в 23:30.
Старый 13.02.2015, 00:19   #4  
ax_mct is offline
ax_mct
Banned
 
2,548 / 1091 (0) ++++++++
Регистрация: 10.10.2005
Адрес: Westlands
Цитата:
Сообщение от kitty Посмотреть сообщение
Не логично, тк при импорте документа , если TableRecid - required, то валидация документа провалится с ошибкой.
На момент импорта ParentTable.RecID вообще еще не существует (
присвоится только при вставке ParentTable записи в Ax и потом должно соответствующее значение автоматически присвоится childTable.TableRecId)

Причем, в prepareForSaveExtended есть соответсвующий код, присваивающий потомкам tableRecId родителя
Сдается мне в прикладной логике ошибка, зачем импортировать несохраненные записи? Какой прикладной смысл?

Система просто рендерит свойство поля таблицы в схему. Раз обязательно там значит обязательно и здесь. Железная логика.
Старый 13.02.2015, 00:50   #5  
kitty is offline
kitty
Участник
 
370 / 30 (2) +++
Регистрация: 24.05.2005
наверное, мы друг друга не понимаем)
Представьте, что вы импортируете заказ. У него еcть шапка и линии
Как можно требовать в сообщении указывать recid шапки на строках, если этот RecId создается только в момент вставки шапки заказа.

Последний раз редактировалось kitty; 13.02.2015 в 01:44.
Старый 13.02.2015, 10:15   #6  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Может, у вас схема документа получилась "какая-то не такая"? Посмотрите, какая схема у тех же заказов на продажу - там прекрасно создаются шапка и строки, несмотря на то, что SalesId создаваемого заказа в строках явно не указывается.
Старый 13.02.2015, 14:26   #7  
kitty is offline
kitty
Участник
 
370 / 30 (2) +++
Регистрация: 24.05.2005
Проблема в том, что на одном приложении все прекрасно, а на другом - нет((

Пытаюсь понять в чем разница. все relations есть. Сравнила классы, таблицы -все одинаковые, перекомпилила не раз, update document service делала, refresh service, пересоздала порт сам и все никак. Схема упорно требует заполнения parentRecid (((.
Временно пришлось сделать поле как mandatory = no.. - подхватил и сделал поле необязательным в схеме Но это ж не выход, на таблице оно должно быть Mandatory((.
Старый 13.02.2015, 16:56   #8  
nano3 is offline
nano3
Участник
 
57 / 24 (1) +++
Регистрация: 21.03.2007
ну может попробовать в методе initMandatoryFieldsExemptionList класса Ax<Имя таблицы> прописать строчку для этого поля - тогда не придется св-во Mandatory поля менять. Хотя конечно странно все это...
Старый 13.02.2015, 18:05   #9  
ax_mct is offline
ax_mct
Banned
 
2,548 / 1091 (0) ++++++++
Регистрация: 10.10.2005
Адрес: Westlands
Цитата:
Сообщение от kitty Посмотреть сообщение
наверное, мы друг друга не понимаем)
Представьте, что вы импортируете заказ. У него еcть шапка и линии
Как можно требовать в сообщении указывать recid шапки на строках, если этот RecId создается только в момент вставки шапки заказа.
Ступил я. Всегда путал экспорт с импортом и дебит с кредитом

На индексе в таблицах свойство AllowDublicates одинаковое?
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
AIF: Не отправляется поле RecId MShi DAX: Программирование 0 20.06.2014 18:17
emeadaxsupport: What changes are required if we change the Business Connector Proxy used by AX 2009 Generated AIF Web services Blog bot DAX Blogs 0 29.03.2010 15:05
Dianne Siebold: Rec Fields Required in AIF Partial Update Blog bot DAX Blogs 0 20.01.2009 09:05
Бинарное поле из XML-документа er1 DAX: Программирование 3 30.06.2008 18:39
Русская локализация Axapta 3 ? SlavaK DAX: Администрирование 59 01.07.2003 22:38
Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

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

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

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