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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 01.08.2010, 19:06   #1  
Blog bot is offline
Blog bot
Участник
 
25,643 / 848 (80) +++++++
Регистрация: 28.10.2006
kamalblogs: Using while select firstonly to avoid validations in Dynamics Ax
Источник: http://kamalblogs.wordpress.com/2010...n-dynamics-ax/
==============

When you execute a select statement to retrieve a single record most of us right the query first. This is followed by a validation to ensure that the query has returned a record. we make it simpler If we right it the way mentioned below…

X++:
static void WhileSelectInsteadoFSelect(Args _args)
{
    InventTable inventTable;
    ;
-----General way---------
    //fetch the record first
    select firstonly forupdate inventtable;

    //add an additional validation
    if (inventTable.recid)
    {
        inventTable.itemName = 'newname';
        inventTable.update();
    }

------Alternate--------------
    //prevents the extra 'if' chek
    while select firstonly forupdate inventTable
    {
        inventTable.itemName = 'newname';
        inventTable.update();
    }

    //can also be used for simple readonly
    while select firstonly inventTable
    {
        Info(inventTable.ItemId);
    }
}

A few of you might already follow it but for the rest it could be a learning





Источник: http://kamalblogs.wordpress.com/2010...n-dynamics-ax/
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору.
Старый 02.08.2010, 08:41   #2  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
По-моему, не все так однозначно. Эта тема обсуждалась также в блоге Эрика Липперта, в заметке Style follows semantics:
Цитата:
The stylistic choices should typically be driven by a desire to clearly communicate the semantics of the program fragment.
Мне кажется, в данном случае использование while может при беглом просмотре кода сбить с толку, поэтому вариант с простым select firstonly и проверкой результата все же предпочтительнее за счет большей выразительности. Кроме того, с точки зрения последующей возможной модификации код лучше сразу писать так, чтобы для его изменения нужно было править как можно меньше строк исходного кода Х++; совсем хорошо, если модификации можно просто дописать в нужном месте, не изменяя строки исходного код Х++ вовсе. Так вот, если понадобится, к примеру, добавить ветвление для случая, когда запись не найдена, то в варианте с if можно будет просто дописать блок else {}, а для while select придется изголяться - к примеру, вводить какую-то переменную-флаг, изменять ее внутри цикла и затем анализировать - вся экономия строк кода моментально улетучится, а читабельности это все совсем не прибавит.
За это сообщение автора поблагодарили: Logger (1), lev (2).
Старый 02.08.2010, 15:41   #3  
petr is offline
petr
Участник
Соотечественники
 
561 / 201 (8) ++++++
Регистрация: 30.05.2005
Адрес: Швейцария
Я использую вариант, упомянутый в блоге в Job'ax и стандарный акспатовский подход (с отдельным селектом без while и последующей проверкой выбранной записи) в бизнес-логике.
Старый 03.08.2010, 07:50   #4  
TasmanianDevil is offline
TasmanianDevil
Мрачный тип
Аватар для TasmanianDevil
Злыдни
 
886 / 389 (14) ++++++
Регистрация: 24.01.2005
Адрес: Томск
Бирюльки дурацкие ...
__________________
Мы летаем, кружимся, нагоняем ужасы ...
Старый 03.08.2010, 14:02   #5  
petr is offline
petr
Участник
Соотечественники
 
561 / 201 (8) ++++++
Регистрация: 30.05.2005
Адрес: Швейцария
Цитата:
Сообщение от TasmanianDevil Посмотреть сообщение
Бирюльки дурацкие ...
Нет, просто понимание того, как работает аксапта и когда какой инструмент надо использовать.
Старый 03.08.2010, 15:20   #6  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Я бы не рекомендовал использовать такой синтаксис.
Кто его знает, может в АХ следующих версий компилятор будет запрещать использование firstonly в while select
Старый 03.08.2010, 23:38   #7  
TasmanianDevil is offline
TasmanianDevil
Мрачный тип
Аватар для TasmanianDevil
Злыдни
 
886 / 389 (14) ++++++
Регистрация: 24.01.2005
Адрес: Томск
Цитата:
Сообщение от petr Посмотреть сообщение
Нет, просто понимание того, как работает аксапта и когда какой инструмент надо использовать.
Есть мнение, что обсуждаемый предмет настолько же элементарен, как правила и способ пользования ложкой.
__________________
Мы летаем, кружимся, нагоняем ужасы ...
 


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

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

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