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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 02.11.2007, 17:57   #1  
kitty is offline
kitty
Участник
 
364 / 26 (1) +++
Регистрация: 24.05.2005
пустой query или нет?
Как можно понять пустые все условия в query или нет без перебора range и не основываясь на SysQuery::countTotal, тк для пустого запроса он возвращает все записи => кол-во ненулевое записей и => сравнивать просто с общим кол-вом записей в таблице некорректно.
Никак?
Старый 02.11.2007, 18:07   #2  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
А в чем проблема перебора всех range запроса?? это во всяком случае много быстрее, чем запрос выполнять к БД
Старый 02.11.2007, 19:38   #3  
Владимир Максимов is offline
Владимир Максимов
Участник
КОРУС Консалтинг
 
1,691 / 1195 (43) ++++++++
Регистрация: 13.01.2004
Записей в блоге: 3
Извратится-то можно, только по сравнению с прямым перебром Range любые способы не дают 100% гарантии верного ответа.

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

X++:
static void Job_QueryRangeEmpty(Args _args)
{
    Query       query;

    QueryBuildDataSource    qbds;
    QueryBuildRange         qbr;

    int         nextI,
                qtyEmpty;
    str         strQuery,
                strQueryExtract;
    ;

#localmacro.emptyValue1
    "= )"
#endmacro
#localmacro.emptyValue2
    "=)"
#endmacro

    // Тестовый Query для проверки
    query = new Query();
    qbds = query.addDataSource(tablenum(InventTable));

    // Одиночные условия
    for (nextI = 1; nextI <= 1 ; nextI++)
    {
        qbr = qbds.addRange(fieldNum(InventTable, ItemId));
        qbr.value(queryValue(''));
    }

    // Диапазон значений
    qbr.value(queryRange('',''));


    // Подсчет количества пустых условий
    strQuery = query.dataSourceNo(1).tostring();
    info(strQuery);
    strQueryExtract = global::strReplace(strQuery,#emptyValue1,"");
    qtyEmpty = (strLen(strQuery)-strLen(strQueryExtract)) / strLen(#emptyValue1);
    strQueryExtract = global::strReplace(strQuery,#emptyValue2,"");
    qtyEmpty += (strLen(strQuery)-strLen(strQueryExtract)) / strLen(#emptyValue2);

    info(strFmt("пустых условий %1", qtyEmpty));
}
Хотя заведомо понятно, что подобный код будет работать только при определенных значениях Range.

По моему, проще написать универсальный код перебора всех Range во всех DataSource.
Старый 03.11.2007, 02:33   #4  
kitty is offline
kitty
Участник
 
364 / 26 (1) +++
Регистрация: 24.05.2005
Цитата:
Сообщение от kashperuk Посмотреть сообщение
А в чем проблема перебора всех range запроса?? это во всяком случае много быстрее, чем запрос выполнять к БД
Спасибо.Да, так и сделала . Думала, мож еще есть какие пути.
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Query sort field autoSum ist DAX in English 4 27.03.2008 16:48
query, compare two fields (by link) Maxim Gorbunov DAX in English 0 22.03.2006 12:04
Проблема с составлением Query axaLearner DAX: Программирование 10 01.12.2005 15:00
Автоматическая подстановка Range в Query Владимир Максимов DAX: Программирование 9 30.03.2004 16:48
Как вытащить информацию о Range из Query raz DAX: База знаний и проекты 1 26.03.2004 11:10

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

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

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