Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Delphi: Базы данных и репортинг > Многопользовательская работа


Автор: Leklerk 1.3.2012, 16:44
Добрый день. Работаю через ADO с SQL Server 2005, запускаю 2 одинаковых exe в одном отменяю (или разрешаю) возможность корректировать данные, а во втором это не отражается, не могу понять, почему. Может, есть какие-то тонкости многопользовательской работы в delphi? 
ADODataSet1 формирует запрос, который показывается в DBGrid; ADODataSet2 выполняется, чтобы узнать значение поля, которое показывает, разрешена ли корректировка. ADOCommand1 и ADOCommand2 изменяют соответствующим образом значение этого поля. Вот код:
Код

procedure TForm1.FormCreate(Sender: TObject);
begin
  ADODataSet1.Open();
  ADODataSet2.Open();
  ADODataSet2.First();
 
 
  if ADODataSet2.Fields[0].Value=1 then begin
    DBGrid1.ReadOnly := FALSE;
    Button3.Caption:='Запретить корректировку';
  end;
 
  if ADODataSet2.Fields[0].Value=0 then begin
    DBGrid1.ReadOnly := TRUE;
    Button3.Caption:='Разрешить корректировку';
  end;            
 
// Кнопка запрета или разрешения корректировки
procedure TForm1.Button3Click(Sender: TObject);
begin
  if Button3.Caption='Запретить корректировку' then begin
    DBGrid1.ReadOnly := TRUE;
    Button3.Caption:='Разрешить корректировку';
    ADOCommand1.Execute();
  end
  else begin
    DBGrid1.ReadOnly := FALSE;
    Button3.Caption:='Запретить корректировку';
    ADOCommand2.Execute();  
  end;
end;
 
// Обновление таблицы и времени каждые 10 секунд
procedure TForm1.Timer1Timer(Sender: TObject);
begin
  ADODataSet1.Close();
  ADODataSet1.Open();  
 
  ADODataSet2.Close();
  ADODataSet2.Open();
  ADODataSet2.First();
 
  if ADODataSet2.Fields[0].Value=1 then begin
    DBGrid1.ReadOnly := FALSE;
    Button3.Caption:='Запретить корректировку';
  end;
 
  if ADODataSet2.Fields[0].Value=0 then begin
    DBGrid1.ReadOnly := TRUE;
    Button3.Caption:='Разрешить корректировку';
  end;
end;

Автор: Данкинг 1.3.2012, 16:50
А что в ADOCommand1-то содержится?

Автор: Leklerk 1.3.2012, 18:06
Цитата

А что в ADOCommand1-то содержится? 

Код

update Табель set Корректировка=0 where
LEFT(Дата, 2)=Day(Getdate())

ADOCommand1 и ADOCommand2 изменяют поле корректировки (на 0 и 1, соответственно).

Автор: Данкинг 1.3.2012, 20:38
А если вторую программу просто перезапустить после корректировки, то работает?

Автор: Leklerk 2.3.2012, 11:13
Цитата(Данкинг @  1.3.2012,  22:38 Найти цитируемый пост)
А если вторую программу просто перезапустить после корректировки, то работает?

Да.


Автор: Данкинг 2.3.2012, 11:33
Ну, попробуй после
Код

Button3.Caption:='Запретить корректировку';
Application.ProcessMessages;

Автор: superVad 2.3.2012, 12:04
Leklerk, какой запрос в ADODataSet2?

Автор: Leklerk 2.3.2012, 12:47
Цитата(superVad @  2.3.2012,  14:04 Найти цитируемый пост)
Leklerk, какой запрос в ADODataSet2? 

Код

select TOP 1 Корректировка from Табель where 
LEFT(Дата, 2)=Day(Getdate())


Добавлено через 11 минут и 4 секунды
Цитата(Данкинг @  2.3.2012,  13:33 Найти цитируемый пост)
Ну, попробуй после

Нет, Данкинг, не помогает.

Автор: Leklerk 13.3.2012, 14:57
Проблема решена. Нужно было вместо
Код

if ADODataSet2.FieldByName('Корректировка').Value=1

писать
Код

if ADODataSet2.FieldByName('Корректировка').Value=TRUE

Автор: Данкинг 13.3.2012, 15:49
Цитата(Leklerk @  13.3.2012,  15:57 Найти цитируемый пост)
Проблема решена. 

А ты изменение данных непосредственно в таблице не проверял, что ли? smile

Добавлено через 24 секунды
Да и написал бы, что поле булево.

Автор: Leklerk 14.3.2012, 07:12
Цитата(Данкинг @  13.3.2012,  17:49 Найти цитируемый пост)
А ты изменение данных непосредственно в таблице не проверял, что ли?

Дело в том, что в таблице записывается именно 1 или 0. 
Цитата(Данкинг @  13.3.2012,  17:49 Найти цитируемый пост)
Да и написал бы, что поле булево. 

Оно не булево.
Цитата

bit (Transact-SQL)
An integer data type that can take a value of 1, 0, or NULL.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)