Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.02.27;
Скачать: CL | DM;

Вниз

Динамическое создание вычисляемого поля   Найти похожие ветки 

 
Pk   (2003-02-10 11:45) [0]

создаю его так:

procedure createfild;
var f:TField;
begin
f:=TField.Create(DataModule1.Query1);
f.Calculated:=true;
f.Name:="Pole1";
DataModule1.Query1.Fields.Add(f);
end;

затем в программе:
DataModule1.Query1.close;
DataModule1.Query1.sql.text:="select * from table1";
createfild;
DataModule1.Query1.open
- вылетает исключение: "поле "" не может быть вычисляемым или lookup".


 
passm ©   (2003-02-10 11:53) [1]

Pk (10.02.03 11:45)> f.FieldName = ?


 
Pk   (2003-02-10 11:57) [2]


> passm © (10.02.03 11:53
f.FieldName :="Pole1"; - результат все тот же. поле "Pole1" не может быть вычисляемым или lookup.


 
passm ©   (2003-02-10 12:25) [3]

Стоп! А почему TField? Это абстрактное поле. Используй конкретное (TIntegerField, TStringField, TFloatField...)
И сначала открывай запрос, а потом уж добаляй поле.


 
Pk   (2003-02-10 13:10) [4]

Использую типизированое поле. Эта ошибка исчезла но возникает другая. Если я создаю поле при открытом запросе вываливается исключение - при открытом наборе даных даную операцию невозможно выполнить, а если я при закрытом создаю это поле то сразу после его создания выполняется событие OnCalculateFields и исключение вылетает уже там (что естествено так как датасет закрыт и все поля на основании которых вычисляется данное, неизвестны)


 
Pk   (2003-02-10 13:17) [5]

забыл сказать: в процедуру createfild добавил F.DataSet:=DataModule1.Query1 - а то появлялось сообщение что поле Pole1 не имеет датасета

кто знает что я не так делаю?


 
Shaman ©   (2003-02-10 13:20) [6]

У тебя скорее всего в возвращаемом наборе присутствует поле с имененм "Pole1".


 
VAleksey ©   (2003-02-10 13:50) [7]

Все поля необходимые в запросе создай сначала, потом открывай.


 
passm ©   (2003-02-10 13:56) [8]

var
f: TIntegerField;
begin
f:= TIntegerField.Create(Application);
f.FieldName:= "FIELD1";
f.FieldKind:= fkCalculated;
f.DataSet:= Query1;
Query1.Open
end;



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

Текущий архив: 2003.02.27;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.022 c
14-87621
MsGuns
2003-02-07 12:09
2003.02.27
Вчера Л.Кучма не одобрил начало военных действий


3-87329
alexander_ua
2003-02-10 17:38
2003.02.27
Блокировка записи в таблице


3-87288
ArtUl
2003-02-10 03:20
2003.02.27
Вопрос по dbexpress


1-87443
яяяяяяя
2003-02-18 16:31
2003.02.27
Types of actual and and formal var parameters must be identical


1-87529
maxim2
2003-02-17 09:00
2003.02.27
Как сделать отдельный hint для каждой ячейки StringGrid