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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 01.08.2014, 08:15   #1  
Vasiliusis is offline
Vasiliusis
Участник
 
225 / 13 (1) ++
Регистрация: 30.01.2013
Клонировать QueryRun
Добрый день!
Вопрос на 5 копеек: у меня есть объект queryRun1. Как мне создать его копию и поместить скажем в queryRun2?
Старый 01.08.2014, 08:21   #2  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,429 / 1772 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
X++:
queryRun2 = new QueryRun(queryRun1.query());
Так?
Старый 01.08.2014, 08:52   #3  
Vasiliusis is offline
Vasiliusis
Участник
 
225 / 13 (1) ++
Регистрация: 30.01.2013
Цитата:
Сообщение от S.Kuskov Посмотреть сообщение
X++:
queryRun2 = new QueryRun(queryRun1.query());
Так?
не пойдет, на датасорсы queryRun1 перед копированием вешаются рэйнджи. В queryRun1.query() этих рэйнджей нету... в query по-моему вообще нельзя рэйнджи вешать, хотя я может ошибаюсь
Старый 01.08.2014, 08:57   #4  
Vasiliusis is offline
Vasiliusis
Участник
 
225 / 13 (1) ++
Регистрация: 30.01.2013
Я соврал, в query их как раз и нужно вешать))) тем не менее, выборка в queryRun1 и queryRun2 не совпадают...
Старый 01.08.2014, 09:02   #5  
Vasiliusis is offline
Vasiliusis
Участник
 
225 / 13 (1) ++
Регистрация: 30.01.2013
В общем, вот почему не сходится: queryRun1 - это запрос датасорса на форме. Датасорс выводится в грид. На грид вешается фильтр... вот это самое значение фильтра при копировании не учитывается. учитываются только рэйнджи, которые прописаны программно (там executeQuery перекрыт...). Вот. как добавить значения фильтра из грида в queryRun2?
Старый 01.08.2014, 09:05   #6  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,429 / 1772 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
Цитата:
Сообщение от Vasiliusis Посмотреть сообщение
хотя я может ошибаюсь
Ошибаетесь. Структура запроса: джойны, рейнджы, сортировки и т.д. - это все задается на уровне query.

QueryRun же это класс отвечающий за перебор записей соответствующего Query.

К стати, на уровне QueryRun ещё задается сопоставление курсоров запроса с конкретными экземплярами временных таблиц, если таковые участвуют в запросе. Вот они видимо не скопируются.

Можно ещё попробовать вот так, но не уверен что это поможет.
X++:
queryRun2 = new QueryRun(queryRun1.pack());
Старый 01.08.2014, 09:07   #7  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,429 / 1772 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
Цитата:
Сообщение от Vasiliusis Посмотреть сообщение
В общем, вот почему не сходится: queryRun1 - это запрос датасорса на форме. Датасорс выводится в грид. На грид вешается фильтр... вот это самое значение фильтра при копировании не учитывается. учитываются только рэйнджи, которые прописаны программно (там executeQuery перекрыт...). Вот. как добавить значения фильтра из грида в queryRun2?
Вам в этом случае нужен не DataSource.QueryRun().Query(), а DataSource.Query().

Извиняюсь, наоборот. Как передать в отчет отфильтрованные данные из формы?

Последний раз редактировалось S.Kuskov; 01.08.2014 в 09:10.
За это сообщение автора поблагодарили: Vasiliusis (1).
Старый 01.08.2014, 09:08   #8  
TasmanianDevil is offline
TasmanianDevil
Мрачный тип
Аватар для TasmanianDevil
Злыдни
 
885 / 389 (14) ++++++
Регистрация: 24.01.2005
Адрес: Томск
Цитата:
Сообщение от S.Kuskov Посмотреть сообщение
но не уверен что это поможет
Поможет, класс SysQuery именно так реализует всякие сервисные подсчеты для передаваемых запросов ...
__________________
Мы летаем, кружимся, нагоняем ужасы ...
За это сообщение автора поблагодарили: S.Kuskov (2).
Старый 01.08.2014, 09:14   #9  
dech is offline
dech
Участник
Аватар для dech
Самостоятельные клиенты AX
 
643 / 347 (13) ++++++
Регистрация: 25.06.2009
Адрес: Омск
Записей в блоге: 3
Цитата:
Сообщение от Vasiliusis Посмотреть сообщение
Я соврал, в query их как раз и нужно вешать))) тем не менее, выборка в queryRun1 и queryRun2 не совпадают...
Значит вы делаете что-то не так...
X++:
static void QueryRunTest(Args _args)
{
    Query                   q;
    QueryRun                qr1, qr2;
    QueryBuildDataSource    qbds;
    InventTable             inventTable;
    ;
    
    q = new Query();
    qbds = q.addDataSource(tablenum(InventTable));
    qbds.addRange(fieldnum(InventTable, ItemId)).value("2320");
    qbds.addSelectionField(fieldnum(InventTable, ItemId));
    qbds.addSelectionField(fieldnum(InventTable, ItemName));
 
    qr1 = new QueryRun(q);
    while (qr1.next())
    {
        inventTable = qr1.get(tablenum(InventTable));
        info(strfmt("%1 (%2)", inventTable.ItemId, inventTable.ItemName));
    }
    
    info("");
    
    qr2 = new QueryRun(qr1.query());
    while (qr2.next())
    {
        inventTable = qr2.get(tablenum(InventTable));
        info(strfmt("%1 (%2)", inventTable.ItemId, inventTable.ItemName));
    }
}
__________________
// no comments
Старый 01.08.2014, 09:14   #10  
Vasiliusis is offline
Vasiliusis
Участник
 
225 / 13 (1) ++
Регистрация: 30.01.2013
Цитата:
Сообщение от S.Kuskov Посмотреть сообщение
Вам в этом случае нужен не DataSource.QueryRun().Query(), а DataSource.Query().

Извиняюсь, наоборот. Как передать в отчет отфильтрованные данные из формы?
DataSource.QueryRun().Query() помогло. благодарю!
Старый 01.08.2014, 09:15   #11  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,429 / 1772 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
Цитата:
Сообщение от TasmanianDevil Посмотреть сообщение
Поможет, класс SysQuery именно так реализует всякие сервисные подсчеты для передаваемых запросов ...
полезный класс, если нужно, например, пересобрать запрос, объеденить. Но заметьте, работает он все равно с классом Query, а не QueryRun. Поэтому вести речь о клонировании именно QueryRun, со всем его контекстом - вообще говоря нельзя.
Старый 01.08.2014, 13:12   #12  
TasmanianDevil is offline
TasmanianDevil
Мрачный тип
Аватар для TasmanianDevil
Злыдни
 
885 / 389 (14) ++++++
Регистрация: 24.01.2005
Адрес: Томск
S.Kuskov, неправда Ваша - всякие count<Всякое>() в нем работают именно с объектом типа QueryRun и именно его клонируют через контейнер, производя вычисления.
__________________
Мы летаем, кружимся, нагоняем ужасы ...
Старый 01.08.2014, 13:57   #13  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,429 / 1772 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
Цитата:
Сообщение от TasmanianDevil Посмотреть сообщение
S.Kuskov, неправда Ваша - всякие count<Всякое>() в нем работают именно с объектом типа QueryRun и именно его клонируют через контейнер, производя вычисления.
Действительно так. Но только это не помогает избежать того о чем я писал. Связь со временной таблицей теряется все равно:

Вот небольшой пример:
X++:
static void JobTEST_QueryRunPack(Args _args)
{
    Query query;
    QueryRun queryRun1, queryRun2;
    TmpABC TmpABC1;
    ;
    
    query = new Query();
    query.addDataSource(tableNum(TmpABC));
    
    TmpABC1.clear();
    TmpABC1.Amount = 123.45;
    TmpABC1.doInsert();
    
    queryRun1 = new QueryRun(query);
    queryRun1.setCursor(TmpABC1);
    info(strfmt("SysQuery::countTotal(queryRun1): %1", SysQuery::countTotal(queryRun1))); // 0
    info("");

    queryRun2 = new QueryRun(queryRun1.pack()); // "клонируем" QueryRun

    info("queryRun2:");
    info("{");
    while (queryRun2.next()) // {}
    {
        TmpABC1 = queryRun2.get(tableNum(TmpABC));
        
        info(strfmt("%1", TmpABC1.Amount));
    }
    info("}");
    info("");

    info("queryRun1:");
    info("{");
    while (queryRun1.next()) // {123,45}
    {
        TmpABC1 = queryRun1.get(tableNum(TmpABC));

        info(strfmt("%1", TmpABC1.Amount));
    }
    info("}");
}
Старый 04.08.2014, 06:58   #14  
TasmanianDevil is offline
TasmanianDevil
Мрачный тип
Аватар для TasmanianDevil
Злыдни
 
885 / 389 (14) ++++++
Регистрация: 24.01.2005
Адрес: Томск
Цитата:
Сообщение от S.Kuskov Посмотреть сообщение
Связь со временной таблицей теряется все равно:
Угу, про времянки, читая ответ по диагонали, я как-то пролетел мимо
__________________
Мы летаем, кружимся, нагоняем ужасы ...
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Всегда ли правильно работает queryrun().query().dataSourceCount() при присоединении пользователем таблиц в настройках стандартного запроса? Aquarius DAX: Программирование 5 26.09.2013 09:52
queryRun метод get SHiSHok DAX: Программирование 6 08.07.2011 16:46
Непонятное подвисание queryRun.next() GBH DAX: Программирование 7 15.11.2010 11:16
Простой QueryRun не работает miklenew DAX: Программирование 13 20.01.2009 14:17
OZKA's DAX Journal: Join между временной и постоянной таблицей через QueryRun. Blog bot DAX Blogs 12 14.01.2009 17:34

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

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

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 02:29.
Powered by vBulletin® v3.8.5. Перевод: zCarot
Контактная информация, Реклама.