Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2004.04.11;
Скачать: [xml.tar.bz2];

Вниз

Добавление полей типа fkCalculated к открытой TADOQuery   Найти похожие ветки 

 
Nikolai_S ©   (2004-03-12 12:35) [0]

Как добавить к открытой TADOQuery вычисляемое поле (TFloatField, fkCalculated). В справке Delphi есть пример добавления поля к датасету, но датасет там должен быть закрыт.


 
Nikolai_S ©   (2004-03-12 12:36) [1]

Сорри, забыл сказать: добавить поле нужно динамически в RunTime


 
Polevi ©   (2004-03-12 12:39) [2]

к открытому никак


 
Nikolai_S ©   (2004-03-12 12:44) [3]

Поле вычисляемое, поэтому нет смысла весь датасет переоткрывать. Это же занимает время - программа будет необоснованно торомозить. Неужели нет выхода добавить вычисляемое поле, не закрывая датасет?


 
ЫЗШКШЕ   (2004-03-12 12:47) [4]

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


 
Nikolai_S ©   (2004-03-12 12:49) [5]

Можно было бы. Но количество этих полей может быть любым. Пользователь задает алгоритм расчета этого поля. Что же их теперь с запасом на 100 или 1000 штук делать? :-)
Хотелось бы не так каряво. Что ж, придется думать, как лучше поступить


 
Polevi ©   (2004-03-12 14:15) [6]

>Nikolai_S ©   (12.03.04 12:44) [3]
можно не переоткрывать, а клонировать на клиенте
хотя тоже криво конечно


 
Nikolai_S ©   (2004-03-12 14:47) [7]

>Polevi
Я тоже об этом подумал. Попробую


 
Johnmen ©   (2004-03-12 15:10) [8]

>Пользователь задает алгоритм расчета этого поля

Так полей или всё-таки поля ?
Да и алгоритм никакого отношения к количеству не имеет...


 
Nikolai_S ©   (2004-03-12 15:25) [9]


> Johnmen ©

Полей. Есть открытый TADOQuery с набором обычных полей (например F1, F2, F3). Пользователь же может добавлять собственные новые поля. Эти поля будут вычисляемыми (FieldKind=fkCalculated). Пользователь, создав, скажем, свое поле, может задать алгоритм его расчета (например F1+F2).

Короче говоря, моя задача: динамически добавлять вычисляемые поля к открытому TADOQuery.


 
Nikolai_S ©   (2004-03-12 15:33) [10]

Еще вопрос: как динамически выполнить команду "Add all fields", которая имеется в Fields Editor"е?

Так как неизвестно, какие поля будут отображены в ADOQuery, то нужно:
1. закрытому ADOQuery присвоить запрос в ADOQuery.SQL;
2. динамически добавить все поля, которые указаны в запросе ADOQuery.SQL (аналог команды "Add all fields" в Feilds Editor"е);
3. можно добавить некоторое количество дополнительных вычисляемых полей про запас.

Не могу найти в справке как реализовать 2-й пункт.


 
Johnmen ©   (2004-03-12 15:48) [11]

ADOQuery1.FieldDefList.Update;   ?


 
Nikolai_S ©   (2004-03-12 16:01) [12]

ADOQuery1.FieldDefList.Update - не подходит, он не выполняет эту операцию. Я проверял


 
Johnmen ©   (2004-03-12 16:23) [13]

ADOQuery1.FieldList.Update;   ?



Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2004.04.11;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.47 MB
Время: 0.04 c
8-1071742003
VasRog
2003-12-18 13:06
2004.04.11
CopyRect и фон


14-1082037100
ghg
2004-04-15 17:51
2004.04.11
вопрос про покрытие на мониторе


3-1079513845
stud
2004-03-17 11:57
2004.04.11
генерация сообщений


14-1079256575
ИМХО
2004-03-14 12:29
2004.04.11
А что в Испании творится?


14-1082439726
bar
2004-04-20 09:42
2004.04.11
Народ. Правда, что студентов лишат отсрочек от армии?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский