Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 19.02.2012, 12:27
Demonuka Demonuka вне форума
Новичок
 
Регистрация: 10.05.2011
Адрес: г. Смоленск
Сообщения: 55
Версия Delphi: 7
Репутация: 10
Вопрос ADO Update

Есть таблица Sost, у нее единственное поле Sostoyanie. В Delphi обновляю его так:
Код:
  ADOQuery5.Active := false;
  ADOQuery5.SQL.Clear;
  ADOQuery5.SQL.Add('Update Sost SET Sostoyanie= "' + Label27.Caption + '";');
  ADOQuery5.ExecSQL;
  ADOQuery5.SQL.Clear;
  ADOQuery5.SQL.Add('SELECT * FROM Каналы');
  ADOQuery5.Active := true;
Ошибок не выдает, но в поле Sostoyanie ничего не записывает. При этом в Label27.Caption не пустое значение.
Что не так?
Ответить с цитированием
  #2  
Старый 27.02.2012, 20:29
Аватар для Guroncheg
Guroncheg Guroncheg вне форума
Прохожий
 
Регистрация: 27.02.2012
Адрес: Украина, Хмельницкий
Сообщения: 4
Версия Delphi: Delphi 7.0.4.45
Репутация: 10
По умолчанию

Во-первых, если не матерится - значит в таблице нет ключевого поля, настоятельно рекомендую его добавить.
Во-вторых, оно все заменяет, надо только делать рефреш таблицы(но тут никуда без ключевого поля), потому -
Код:
ADOTable1.Active:=false;
ADOTable1.Active:=true;

И, еще, Update без where заменит тебе ВСЕ поля таблицы.
Измени запрос:
Код:
'Update Таблица1 SET Sost= "' + Label27.Caption + '" where sost="'+Edit1.Text+'"'
В результате выйти должно так:
Код:
 ADOQuery5.Active := false;
  ADOQuery5.SQL.Clear;
  ADOQuery5.SQL.Add('Update Таблица1 SET Sost= "' + Label27.Caption + '" where sost="'+Edit1.Text+'"');
  ADOQuery5.ExecSQL;
  ADOTable1.Active:=false;
  ADOTable1.Active:=true;
  ADOQuery5.SQL.Clear;
  ADOQuery5.SQL.Add('SELECT * FROM Каналы');
  ADOQuery5.Active := true;
Ответить с цитированием
  #3  
Старый 28.02.2012, 06:26
Аватар для Ildar-tsr
Ildar-tsr Ildar-tsr вне форума
Местный
 
Регистрация: 09.08.2011
Адрес: г.Сургут, ХМАО
Сообщения: 453
Репутация: 7402
По умолчанию

Цитата:
Сообщение от Demonuka
Есть таблица Sost, у нее единственное поле Sostoyanie. В Delphi обновляю его так:
Сравни со своим кодом (обрати внимание на кавычки):
Код:
  with ADOQuery5 do
    Close;
    SQL.Clear;
    SQL.Add('update sost set sostoyanie = ''' + label27.caption + '''');
    ExecSQL;
    SQL.Clear;
    SQL.Add('select * from Каналы');
    Open;
  end;
Как заметили выше, данный запрос заменить все записи таблицы. Во избежание добавь where.
__________________
Google в помощь
Ответить с цитированием
  #4  
Старый 28.02.2012, 08:37
Demonuka Demonuka вне форума
Новичок
 
Регистрация: 10.05.2011
Адрес: г. Смоленск
Сообщения: 55
Версия Delphi: 7
Репутация: 10
По умолчанию

Спасибо за отклики...Уже и не надеялся на ответы...:-)
Guroncheg прав. Не работало потому что ключевого поля не было. Однако, стоит заметить, что Update может работать и без ключевого поля, но заменяемая ячейка не должна быть пустой (как было у меня). Вобщем, всем спасибо..)
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 23:57.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025