05.12.2001, 15:00 | #1 |
Administrator
|
Быстрый способ добавить фильтр на FormDataSource
Чтобы быстро добавить ограничение на значения одного из полей источника данных, например, для фильтрации, следует:
X++: this.query().dataSourceNo(1).addRange(fieldNum(MyTable,MyField)).value(MyValue); |
|
05.12.2001, 15:03 | #2 |
Продавец игрушек
|
Приносим свои извинения
Сегодня эта тема была утерена, приносим всем свои извинения, а в особенности Сергею и Андрею.
Причина: мои кривые руки. Некорректно удалил дублирующиеся сообщения. Хотел как лучше... |
|
05.12.2001, 15:04 | #3 |
Administrator
|
Вопрос
Цитата:
Чтобы быстро добавить ограничение на значения одного из полей источника данных,например, для фильтрации, следует:
Перекрыть метод FormDataSource::Init(). FormDataSource - это, что ? Это таблица в разделе DataSource у какой-либо формы ? Если это так, то почему когда я набираю: this.query(). у меня появляется сообщение "информация из таблицы подстановок не доступна" ? Спасибо. <a href = "http://www.axforum.info/forums/member.php?s=&action=getinfo&userid=24">Андрей.</a> |
|
05.12.2001, 15:07 | #4 |
Administrator
|
Re: Вопрос
Здравствуйте, Андрей.
Вы поняли совершенно верно: FormDataSource - это один из DataSource формы, которые расположены в ветви DataSource у формы (на одном уровне с Methods и Designs). Из кода в форме к объекту типа FormDataSource можно получить доступ через переменную вида <имя DataSource>_ds (например, SalesTable_ds). Если вы перекрываете метод Init, вы можете использовать this для доступа к FormDataSource. Недоступность информации из таблицы подстановок не есть ошибка. Дело в том, что система IntelliSence Axapta, которая отвечает за подстановку, устроена так, что она обрабатывает лишь подстановки первого уровня. Вы же пытаетесь заставить ее обработать более глубокую подстановку. Если Вы хотите воспользоваться IntelliSence, заведите переменную типа Query и присвойте ей значение this.query(). Продолжая по аналогии Вы получите подстановки на всех уровнях. Однако, это лишь вопрос удобства разработки и отладки. Для краткости вы можете воспользоваться нашим текстом.
__________________
Not registered yet? Register here! Have comments, questions, suggestions or anything else regarding our web site? Don't hesitate, send them to me |
|
07.12.2001, 15:55 | #5 |
Moderator
|
Да действительно, мое сообщение затерялось. Но ничего, напишу еще раз.
Спасибо Max. Спасибо за предыдущее объяснение, но у меня все равно не получается фильтровать записи при открытии формы. Я создал форум и добавил в нее источник данных, например BOMTable. Я раскрываю эту таблицу и перекрываю метод Init. В нем я пишу следующее: this.query().dataSourceNo(1).addRange(fieldNum(BomTable,BOMId)).value("001"); или BOMTable_ds.query().dataSourceNo(1).addRange(fieldNum(BomTable,BOMId)).value("001"); Форма копмилируется. Но при запуске формы появляется сообщение о ошибке времени выполнения: empty class object не инициализирован. Трассировка стека: \Procedures\<Global>\dataSourceNo \Forms\Form3\Data Sources\BOMTable\Methods\init // Это тот метод который я перекрываю. Если же я создаю кнопку, перекрываю метод clicked и добавляю туда эту же строку, то принажатии на кнопку сообщение об ошибке не появляется, но и с Grid'ом на который я вывожу источник данных тоже ничего не происходит. В чем дело ? Спасибо. Андрей. |
|
08.12.2001, 03:29 | #6 |
Продавец игрушек
|
Цитата:
Изначально опубликовано Андре
... перекрываю метод Init. В нем я пишу следующее: this.query().dataSourceNo(1).addRange(fieldNum(BomTable,BOMId)).value("001"); Я повторил вcё как ты писал, и понял -- быстрее всего решить проблему, если перекрыть метод <b>executeQuery</b>, а не <b>Init</b>: X++: public void executeQuery() { this.query().dataSourceNo(1).addRange(fieldNum(BomTable,BOMId)).value("001"); super(); }
__________________
С уважением, Роман Кошелев. |
|
08.12.2001, 03:32 | #7 |
Продавец игрушек
|
Цитата:
Изначально опубликовано Андре
Если же я создаю кнопку, перекрываю метод clicked и добавляю туда эту же строку, то принажатии на кнопку сообщение об ошибке не появляется, но и с Grid'ом на который я вывожу источник данных тоже ничего не происходит. В чем дело ? ВЫзови что-то вроде BOMTable_ds.research() или BOMTable_ds.executeQuery() и грид перерисуется.
__________________
С уважением, Роман Кошелев. |
|
09.12.2001, 18:19 | #8 |
Administrator
|
Ошибка времени выполнения
Здравствуйте, Андрей.
Возможно, что причина вашей ошибки - не совсем корректная формулировка с нашей стороны. Цитата:
Перекрыть метод FormDataSource::Init()
Смысл сообщения об ошибке, выдаваемого Вам, заключается в том, что Вы пытаетесь использовать методы объекта, который еще не иниализирован (инициализация проходит именно в методе super()). Решение проблемы через executeQuery также корректно (к этому момент объект FormDataSource уже инициализирован), но Вы должны осознавать, что каждый раз при вызове этого метода (а он, в отличие от init, вызывается очень часто) будет происходить присваивание query для dataSource. Теперь, если Вы захотите изменить значение query во время работы (например, по нажатию кнопки), Вам придется добавлять сравнительно сложный код с условиями ветвления в executeQuery. В случае использования метода init Вы присваиваете query лишь начальное значение, которое затем сможете как угодно менять в любых методах своей формы. Вообще говоря, метод executeQuery лишь выполняет запрос, который присвоен полю query элемента FormDataSource. То, что у Вас не происходила фильтрация при нажатии на кнопку, объясняется тем, что Вы лишь присваивали полю query новые параметры запроса. Для выполнения запроса следует использовать метод executeQuery. В качестве примера посмотрите мой проект. Я переопределял методы init у InventTable и clicked у кнопки. Попробуйте убрать вызов метода clearRanges.
__________________
Not registered yet? Register here! Have comments, questions, suggestions or anything else regarding our web site? Don't hesitate, send them to me |
|
24.04.2002, 12:01 | #9 |
Moderator
|
Цитата:
Изначально опубликовано Андре
... перекрываю метод Init. В нем я пишу следующее: this.query().dataSourceNo(1).addRange(fieldNum(BomTable,BOMId)).value("001"); Цитата:
Роман Кошелев
Скорее всего, ошибка в том, что "не успевает" проинициализироваться query. Я повторил вcё как ты писал, и понял -- быстрее всего решить проблему, если перекрыть метод executeQuery, а не Init: public void executeQuery() { this.query().dataSourceNo(1).addRange(fieldNum(BomTable,BOMId)).value("001"); super(); } Так вроде всё работает. Метод executeQuery срабатывает каждый раз при добавлении/снятии фильтра. Соответственно на форме установки фильтра при каждой установке/снятии фильтра добавляется еще одна строка. Наверно корректнее будет так: public void executeQuery() { this.query().dataSourceNo(1).clearRange(fieldNum(BomTable,BomId)); this.query().dataSourceNo(1).addRange(fieldNum(BomTable,BOMId)).value("001"); super(); } И еще. При добавлении этого метода и открытии формы установки фильтра, там по умолчанию можно фильтровать только по одному полю - тому, на которое мы установили фильтр. А если бы я не создавал этот метод, то в форме установки фильтра отображались бы строки фильтрации по другим полям. Куда они пропадают ? |
|
27.05.2002, 10:39 | #10 |
Участник
|
Попробуйте перенести ваш код
this.query().dataSourceNo(1).addRange(fieldNum(BomTable,BOMId)).value("001"); в инит'е Дата сорса за super() т.е. void init() { ... super(); this.query().dataSourceNo(1).addRange(fieldNum(BomTable,BOMId)).value("001"); } То, что он вылетает с ошибкой трасировкой ... и т.д. - это понятно, на непроинициалицированный дата сорс вы ложите ограничение ... в нашей практике мы поступаем несколько по другому ... ClassDeclaration формы объявляем переменную { ... QueryBuildRange myRange; ... } в ините дата сорса инициализируем ее после супера ... super(); .... myRange = this.query().dataSourceNo(1).addRange(fieldNum(BomTable,BOMId)); ... в executeQuery этого же дата сорса прописуем до супера ... myRange.value('001'); super(); ... Вот. Но даже не это вызывает интерес ... Более интересна проблема решить как не сбив уже наложенные пользователем фильтры (правой клавишей на поле , фильтр) наложить свой ... фильтр. Я по свободке капался и даже нарыл как это можно сделать, но по какой-то причине не записал ..., может кто знает?
__________________
Всем привет!!! |
|
|
За это сообщение автора поблагодарили: Vasil (1). |
27.05.2002, 13:05 | #11 |
Участник
|
<pre>
QueryBuildDataSource dataSource; QueryBuildRange queryRange; str value; int RangeCount; rangeCount = dataSource.rangeCount(); for( fieldNo = 1; fieldNo <= rangeCount; ++fieldNo ) { queryRange = dataSource.range(fieldNo); if( queryRange.field() != %FieldName% || queryRange.status() != %RangeStatus% ) continue; // Нашли критерий. Добавляем наш фильтр во все критерии по этому полю. value = queryRange.value(); if( value ) { // критерий уже задан. Добавляем свой queryRange.value(value+','+%RangeValue%); } else { // Критерий задан. Но он пустой. Странно. Но продолжаем queryRange.value(%RangeValue%); } } </pre> ты уверен, что без программирования никак? ты уверен, что то что ты хочешь не решается штатными средствами? |
|
27.05.2002, 17:53 | #12 |
Участник
|
У важаемый mazzy!!!
Думаю для людей популяризирующих аксапту несколько не уместен Ваш тон!!! нет я не уверен, что без пограмирования никак, нет я не уверен, что то, что я хочу, не решается програмными ср-ми, но именно для этого я и листаю, этот форум, именно для этого я и пытаюсь учавствовать в дисскусиях, или я не понимаю для чего был создан данный форум. За предложенное Вами решение - спасибо (програмный код), - проверял работает, понравилось.
__________________
Всем привет!!! |
|
27.05.2002, 19:37 | #13 |
Участник
|
vegtabl, извини.
|
|
23.04.2003, 10:18 | #14 |
Участник
|
Re: Вопрос
Цитата:
Если это так, то почему когда я набираю:
this.query(). у меня появляется сообщение "информация из таблицы подстановок не доступна" ? PHP код:
__________________
Roman "Daemon" Krivov Specialist of “CORUS Group” IT department |
|
23.04.2003, 15:20 | #15 |
Administrator
|
Вы что-то хотели спросить?
__________________
Not registered yet? Register here! Have comments, questions, suggestions or anything else regarding our web site? Don't hesitate, send them to me |
|
23.04.2003, 15:31 | #16 |
Участник
|
Цитата:
Изначально опубликовано Maxim Gorbunov
Вы что-то хотели спросить? Упс! Говорили же мне "Внимательно читай хворумы!" оказывается такой ответ уже был... Сорри!
__________________
Roman "Daemon" Krivov Specialist of “CORUS Group” IT department |
|
25.04.2003, 15:47 | #17 |
Смотрящий поверх деревьев (Варварский отморозок)
|
<Зохавано мудератором>
за неуплату
__________________
It's a dirty job, but someone's got to do it. So? |
|
28.04.2003, 09:27 | #18 |
Administrator
|
Цитата:
Изначально опубликовано PlasticinE
Кстати, это не вами был изначально усилен AxForum?
__________________
Not registered yet? Register here! Have comments, questions, suggestions or anything else regarding our web site? Don't hesitate, send them to me |
|
28.04.2003, 13:26 | #19 |
Смотрящий поверх деревьев (Варварский отморозок)
|
<Зохавано мудератором>
за неуплату
__________________
It's a dirty job, but someone's got to do it. So? |
|
29.04.2003, 10:35 | #20 |
Участник
|
Цитата:
Изначально опубликовано PlasticinE
Максим! ну что же вы?! Вдруг бы человек признался? - нам было бы кого пинать ногами...
__________________
Roman "Daemon" Krivov Specialist of “CORUS Group” IT department |
|
|
|