Приношу свои извинения за не совсем полный код. Вот вся процедура:
Код:
procedure TOptimization.Method(k1: integer; k2: integer; k3: integer; k4: integer; alpha: real; betha: real; X1: real; X2: real; dX: real; E: real;
calcnum: Integer; CType: integer);
var itcount, i : integer;
BEGIN
Form1.DBGrid1.DataSource.DataSet.DisableControls; //попытка исправить Access Violation
//запись в таблицу ITER
i := 1;
itcount := RandomRange(1, 100);
for i := 1 to itcount-1 do
BEGIN
DM.IBTable3.Append; //БЫЛА ОШИБКА "cannot focus a disabled or invisible window"
DM.IBTable3.FieldByName('IT_ID').AsInteger := 0; //ACCESS VIOLATION ... формируется в базе триггером
DM.IBTable3.FieldByName('CALCNUM').AsInteger := CALCNUM; //для какого расчета..
DM.IBTable3.FieldByName('ITERNUM').AsInteger := 0; //ФОРМИРУЕТСЯ СЕЙЧАС В БАЗЕ триггером. но возможно придется ставить здесь
DM.IBTable3.FieldByName('X1K').AsFloat := i; //координата X
DM.IBTable3.FieldByName('X2K').AsFloat := RandomRange(1, 50) ; //координата Y
DM.IBTable3.FieldByName('FK').AsFloat := RandomRange(0, 50);
DM.IBTable3.POST;
END;
DM.IBTable3.Refresh;
Form1.DBGrid1.DataSource.DataSet.EnableControls; //попытка исправить Access Violation
//дозаполнение полей в таблице CALC - step, criterion, x1optim, x2optim, foptim
with DM.IBQuery2 do
BEGIN
Close;
SQL.Clear;
SQL.Add('update calc set step = :step, criterion = :criterion,');
SQL.Add(' x1optim = :x1optim, x2optim = :x2optim, foptim = :foptim ');
SQL.Add('where calcnum = :calcnum');
Params.ParamByName('calcnum').Value := CALCNUM;
Params.ParamByName('step').Value := (itcount/2.0) -1;
Params.ParamByName('criterion').Value := 1.8;
Params.ParamByName('x1optim').Value := 21; //брать последнюю итерацию из базы..
Params.ParamByName('x2optim').Value := 21; //брать последнюю итерацию из базы..
Params.ParamByName('foptim').Value := 0.11 ; //брать последнюю итерацию из базы..
ExecSQL;
END;
DM.IBTable1.Refresh;
END;
Если убрать вторую часть с IBQUERY - то все работает просто ОТЛИЧНО и не ругается..!!
HEPL!!!!! Неужели придется разбивать на две разные процедуры. Но это, чуется мне, бред полный