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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 12.02.2010, 20:16   #1  
wojzeh is offline
wojzeh
Участник
Аватар для wojzeh
Соотечественники
 
674 / 512 (19) +++++++
Регистрация: 27.04.2006
Адрес: Montreal
SysUserInfo find
коллеги, может кто-нибудь мне объяснить, зачем в 4-й версии аксапты метод find всеми нами уважаемой таблицы SysUserInfo пытается чего-то внутри себя создавать?

как-то это выглядит против джентльменских правил.

X++:
static SysUserInfo find(userId _userId = curuserid(), boolean _forupdate = false)
{
    SysUserInfo parameter;

    parameter.selectForUpdate(_forupdate);

    select firstonly parameter
        index UserIdx
        where parameter.Id == _userId;

    if (!parameter && !isConfigMode())  // Cannot create parameter before all tables are synced.
    {
        Company::createParameter(parameter);
    }

    return parameter;
}
__________________
Felix nihil admirari

Последний раз редактировалось wojzeh; 12.02.2010 в 21:16. Причина: опечатка
Старый 12.02.2010, 20:30   #2  
Mykola Galak is offline
Mykola Galak
Участник
 
40 / 39 (2) +++
Регистрация: 24.01.2008
Адрес: Copenhagen
Цитата:
Сообщение от wojzeh Посмотреть сообщение
коллеги, может кто-нибудь мне объяснить, зачем в 4-й версии аксапты метод find всеми нами уважаемого класса SysUserInfo пытается чего-то внутри себя создавать?
Так делают в случаях, когда надо заполнить табличку с параметрами дефолтными значениями при первом обращении к параметрам. Поищите по другим таблицам - такой подход используется довольно часто.
Старый 12.02.2010, 21:20   #3  
wojzeh is offline
wojzeh
Участник
Аватар для wojzeh
Соотечественники
 
674 / 512 (19) +++++++
Регистрация: 27.04.2006
Адрес: Montreal
на мой взгляд, это неверный подход. ибо если передать пустое значение в качестве userId, то оно будет заменено на ид текущего пользователя по умолчанию, и система попытается продублировать уже существующего пользователя, что, в свою очередь, приведёт к исключительной ситуации.

насколько я помню, каждая таблица должна иметь метод find, но нигде не говорилось, что он должен что-то создавать при этом. оправданным был бы подход в создании либо метода findAndCreateIfNotExist или хотя бы параметра наподобие forUpdate.
__________________
Felix nihil admirari
Старый 17.02.2010, 14:30   #4  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Цитата:
Сообщение от wojzeh Посмотреть сообщение
на мой взгляд, это неверный подход. ибо если передать пустое значение в качестве userId, то оно будет заменено на ид текущего пользователя по умолчанию, и система попытается продублировать уже существующего пользователя, что, в свою очередь, приведёт к исключительной ситуации.
Пожалуй, код реализован некорректно, потому что пытается всегда создать запись для текущего пользователя, даже если передать ему в качестве _userId код другого пользователя, для которого запись еще не создана. Но одна некорректная реализация не означает, что используемый подход инициализации данных при первом обращении (т.н. ленивая инициализация) в целом не имеет права на жизнь.
Цитата:
Сообщение от wojzeh Посмотреть сообщение
насколько я помню, каждая таблица должна иметь метод find, но нигде не говорилось, что он должен что-то создавать при этом. оправданным был бы подход в создании либо метода findAndCreateIfNotExist или хотя бы параметра наподобие forUpdate.
Посмотрите по перекрестным ссылкам, в скольки местах вызывается Company::createParameter(), - это более чем 90 параметрических таблиц. Если бы для этой инициализации использовался некий отдельнный метод findAndCreateIfNotExist() либо специальный параметр, то пришлось во всем коде вместо find() для этих таблиц вызывать этот отдельнный метод либо, соответственно, всегда передавать этот параметр, поскольку неизвестно заранее, какой кусок кода первым обратится к той или иной параметрической таблице.
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
To find objects in AOT with particular properties Blog bot DAX Blogs 1 26.04.2008 07:33
Kashperuk Ivan: Hotkeys and Find vs Filter in Dynamics AX 2009 Blog bot DAX Blogs 2 11.03.2008 12:06
daxmy: AOT Find function Blog bot DAX Blogs 0 17.08.2007 01:23
Palle Agermark: Use regular expressions in the Find dialog Blog bot DAX Blogs 1 22.03.2007 21:01
Dynamics AX Geek: cross-references & find Blog bot DAX Blogs 0 28.10.2006 16:40

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

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

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