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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 01.10.2010, 11:24   #1  
Prophetic is offline
Prophetic
Участник
 
113 / 15 (1) ++
Регистрация: 08.12.2009
Работа с DataSource в executeQuery()
Здравия всем.

Создал форму, в методе executeQuery() одного из DataSource установил фильтры (addRange). Подскажите, пожалуйста, как оптимально пройтись по всем записями этого DataSource (нужно для вставки записей в другую таблицу на основе полей текущей).
Старый 01.10.2010, 11:28   #2  
lev is offline
lev
Ищущий знания...
Аватар для lev
Oracle
MCBMSS
Axapta Retail User
 
1,723 / 491 (20) +++++++
Регистрация: 18.01.2005
Адрес: Москва
Цитата:
Сообщение от Prophetic Посмотреть сообщение
Здравия всем.

Создал форму, в методе executeQuery() одного из DataSource установил фильтры (addRange). Подскажите, пожалуйста, как оптимально пройтись по всем записями этого DataSource (нужно для вставки записей в другую таблицу на основе полей текущей).
где то на форуме вроде уже обсуждалось, некогда искать.
вот пример кода:
X++:
for (table1 = (Table_DS.getFirst(1, 1) ? Table_DS.getFirst(1, 1) : Table );  table1 ; table1 = Table_DS.getNext())
{
...
}
P.S. т.е. так же как и обработка свойства MultiSelect y кнопки.
__________________
"Страх перед возможностью ошибки не должен отвращать нас от поисков истины." (с)
С Уважением,
Елизаров Артем
За это сообщение автора поблагодарили: Prophetic (1).
Старый 01.10.2010, 11:30   #3  
Wamr is offline
Wamr
----------------
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
 
1,737 / 858 (32) +++++++
Регистрация: 15.01.2002
Адрес: Москва
Записей в блоге: 7
Лучше взять из DS квери, сделать QueryRun и уже из него брать записи.
За это сообщение автора поблагодарили: Prophetic (1).
Старый 01.10.2010, 11:30   #4  
tricky is offline
tricky
Участник
 
140 / 64 (3) ++++
Регистрация: 03.05.2005
Адрес: Гуково
Самый оптимальный способ - это написать запрос с теми же таблицами, что и DS и теми же Range'ми - и пройтись по записям
За это сообщение автора поблагодарили: Prophetic (1).
Старый 01.10.2010, 11:34   #5  
lev is offline
lev
Ищущий знания...
Аватар для lev
Oracle
MCBMSS
Axapta Retail User
 
1,723 / 491 (20) +++++++
Регистрация: 18.01.2005
Адрес: Москва
Цитата:
Сообщение от Wamr Посмотреть сообщение
Лучше взять из DS квери, сделать QueryRun и уже из него брать записи.
Ну это смотря что нужно.
Мне показалось, что топикстартеру надо обработать именно те записи, которые выбраны на форме, т.е. которые выделены курсором.

З.Ы. конечно если нужны записи, которые выбираются по фильтру указанному в форме, то полностью с вами согласен.
__________________
"Страх перед возможностью ошибки не должен отвращать нас от поисков истины." (с)
С Уважением,
Елизаров Артем
Старый 01.10.2010, 11:38   #6  
Prophetic is offline
Prophetic
Участник
 
113 / 15 (1) ++
Регистрация: 08.12.2009
Цитата:
Сообщение от lev Посмотреть сообщение
Ну это смотря что нужно.
Мне показалось, что топикстартеру надо обработать именно те записи, которые выбраны на форме, т.е. которые выделены курсором.

З.Ы. конечно если нужны записи, которые выбираются по фильтру указанному в форме, то полностью с вами согласен.
Правильно там, где ЗЫ.
Старый 01.10.2010, 11:39   #7  
Prophetic is offline
Prophetic
Участник
 
113 / 15 (1) ++
Регистрация: 08.12.2009
Цитата:
Сообщение от Wamr Посмотреть сообщение
Лучше взять из DS квери, сделать QueryRun и уже из него брать записи.
А с формой ничего не случится?
Старый 01.10.2010, 11:52   #8  
lev is offline
lev
Ищущий знания...
Аватар для lev
Oracle
MCBMSS
Axapta Retail User
 
1,723 / 491 (20) +++++++
Регистрация: 18.01.2005
Адрес: Москва
Цитата:
Сообщение от Prophetic Посмотреть сообщение
А с формой ничего не случится?
если проинициализируете новые query и queryRun на основании Table_ds.query(), то ничего не случиться

пример для наглядности:
X++:
Query       query;
QueryRun    queryRun;
;

query       = new Query(Table_ds.queryRun().query().pack()); 
queryRun    = new QueryRun(query);

info(query.dataSourceNo(1).toString());
__________________
"Страх перед возможностью ошибки не должен отвращать нас от поисков истины." (с)
С Уважением,
Елизаров Артем

Последний раз редактировалось lev; 01.10.2010 в 12:49. Причина: изменил пример кода
Старый 01.10.2010, 11:55   #9  
twilight is offline
twilight
MCTS
MCBMSS
 
871 / 237 (9) ++++++
Регистрация: 17.10.2004
Адрес: Королёв
Цитата:
Сообщение от Wamr Посмотреть сообщение
Лучше взять из DS квери, сделать QueryRun и уже из него брать записи.
Тут нужно только помнить, что query датасорса не всегда содержит фильтр, наложенный на форму ). Сам недавно с этим столкнулся.
__________________
I could tell you, but then I would have to bill you.
Старый 01.10.2010, 11:57   #10  
Prophetic is offline
Prophetic
Участник
 
113 / 15 (1) ++
Регистрация: 08.12.2009
Цитата:
Сообщение от twilight Посмотреть сообщение
Тут нужно только помнить, что query датасорса не всегда содержит фильтр, наложенный на форму ). Сам недавно с этим столкнулся.
Вроде, фильтр как раз накладывается именно на query datasource.
Старый 01.10.2010, 11:59   #11  
lev is offline
lev
Ищущий знания...
Аватар для lev
Oracle
MCBMSS
Axapta Retail User
 
1,723 / 491 (20) +++++++
Регистрация: 18.01.2005
Адрес: Москва
Цитата:
Сообщение от twilight Посмотреть сообщение
Тут нужно только помнить, что query датасорса не всегда содержит фильтр, наложенный на форму ). Сам недавно с этим столкнулся.
Очень интересно, это в каких случаях?
Просто интересно как тогда данные фильтруются, что бы правильно на форме отобразиться...
Проясните пожалуйста
__________________
"Страх перед возможностью ошибки не должен отвращать нас от поисков истины." (с)
С Уважением,
Елизаров Артем
Старый 01.10.2010, 12:00   #12  
Raven Melancholic is offline
Raven Melancholic
Участник
Аватар для Raven Melancholic
Самостоятельные клиенты AX
Лучший по профессии 2015
 
2,160 / 1289 (47) ++++++++
Регистрация: 21.03.2005
Адрес: Москва-Петушки
Цитата:
Сообщение от twilight Посмотреть сообщение
Тут нужно только помнить, что query датасорса не всегда содержит фильтр, наложенный на форму ). Сам недавно с этим столкнулся.
Естественно, если есть QueryRun датасорса, то Query нужно брать именно из QueryRun, а не из самого датасорса, что-то вроде:
X++:
loqQuery = qqq_ds.queryRun() ? qqq_ds.queryRun().query() : qqq_ds.query();
Старый 01.10.2010, 12:03   #13  
tricky is offline
tricky
Участник
 
140 / 64 (3) ++++
Регистрация: 03.05.2005
Адрес: Гуково
Цитата:
Сообщение от Raven Melancholic Посмотреть сообщение
Естественно, если есть QueryRun датасорса, то Query нужно брать именно из QueryRun, а не из самого датасорса, что-то вроде:
X++:
loqQuery = qqq_ds.queryRun() ? qqq_ds.queryRun().query() : qqq_ds.query();
Если я не ошибаюсь, QueryRun есть всегда, правда после выполнения super() executeQuery датасоурса.
Старый 01.10.2010, 12:43   #14  
_scorp_ is offline
_scorp_
Участник
Аватар для _scorp_
MCBMSS
 
488 / 369 (13) ++++++
Регистрация: 25.07.2007
Адрес: Москва
В query() хранится DS который был сформирован в момент инициализации датасорса. Потом этот query копируется в queryRun и форма работает уже с ним. Получается что на форме есть два запроса: 1. Сформированный в момент инициализации. 2. Текущий запрос формы из queryRun. После того как форма запустилась нужно работать с запросом из queryRun. При сбросе всех фильтров и сортировок на форме запрос из query() копируется в queryRun().query().
За это сообщение автора поблагодарили: lev (3), tricky (1), Prophetic (1).
Старый 01.10.2010, 13:16   #15  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,887 / 3152 (113) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Надо еще дайналинки учесть. Если есть дайналинки то запрос просто так не скопируешь. Игнорировать их нельзя.
За это сообщение автора поблагодарили: tricky (2), Prophetic (1).
Старый 01.10.2010, 13:44   #16  
Wamr is offline
Wamr
----------------
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
 
1,737 / 858 (32) +++++++
Регистрация: 15.01.2002
Адрес: Москва
Записей в блоге: 7
Цитата:
Сообщение от Prophetic Посмотреть сообщение
в методе executeQuery() одного из DataSource установил фильтры (addRange).
Как раз вот этот query и нужен, а уж в DS он или в DS.queryRun, надеюсь автор сам разберется
За это сообщение автора поблагодарили: Prophetic (1).
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Kashperuk Ivan: Tutorial: refresh, reread, research, executeQuery - which one to use? Blog bot DAX Blogs 20 04.04.2017 13:23
C# and AX Development: Updating the caller Form/DataSource Blog bot DAX Blogs 0 18.07.2009 02:28
Обновление таблицы в DataSource при ее изменении Андре DAX: База знаний и проекты 7 22.04.2008 13:16
Заполнение DataSource из постоянной и временной таблиц m_ax DAX: Программирование 2 21.06.2007 13:08
Перемещение по записям отфильтрованного DataSource Андре DAX: Программирование 3 18.06.2002 08:37

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

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

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