Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
4 / 4 / 1
Регистрация: 03.06.2011
Сообщений: 35

запросы добавления,обновления,удаления

05.12.2011, 18:39. Показов 3091. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
сделал по примеру,даже пустую базу создал с одной таблице но запросы не работают
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
procedure TForm1.BtAddClickClick(Sender: TObject);
begin
 
  with DataModule2 do
 
  begin
    workquery.SQL.Clear;
    workquery.SQL.Add('insert into KLIENT (KLIENT_ID, ADRES, TELEPHONE, FIO, KLIENT_PK, KLIENT_FK)');
    workquery.SQL.Add('VALUES (:newfio, :newtelephone, :newadres, :newklient_id, :newklient_pk, :newklient_fk)');
    workquery.ParamByName('newfio').AsString:=edit1.Text;
    workquery.ParamByName('newtelephone').AsInteger:=StrToInt(Edit2.Text);
    workquery.ParamByName('newadres').AsString:=edit3.Text;
    workquery.ParamByName('newklient_id').AsInteger:=StrToInt(Edit4.Text);
    workquery.ParamByName('newklient_pk').AsInteger:=StrToInt(Edit5.Text);
    workquery.ParamByName('newklient_fk').AsInteger:=StrToInt(Edit6.Text);
   try
 
    workquery.ExecSQL;
    workquery.Transaction.Commit;
    IBQuery.Open;
    Except
 
      showmessage('ошибка операции добавления');
 
    end;
 
  end;
 
end;
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
procedure TForm1.Button2Click(Sender: TObject);
begin
  with DataModule2 do
  begin
    workquery.SQL.Clear;
    workquery.SQL.Add('update phone set fio=:newfio, TELEPHONE=:newtelephone, ADRES=:newadres, KLIENT_ID=:newklient_id, KLIENT_PK=:newklient_pk, KLIENT_FK=:newklient_fk');
    workquery.SQL.Add('WHERE (fio=:newfio)  (TELEPHONE=:newtelephone)  (ADRES=:newadres)  (KLIENT_ID=:newklient_id)  (KLIENT_PK=:newklient_pk)  (KLIENT_FK=:newklient_fk)');
    workquery.ParamByName('newfio').AsString:=edit1.Text;
    workquery.ParamByName('newtelephone').AsInteger:=StrToInt(Edit2.Text);
    workquery.ParamByName('newadres').AsString:=edit3.Text;
    workquery.ParamByName('newklient_id').AsInteger:=StrToInt(Edit4.Text);
    workquery.ParamByName('newklient_pk').AsInteger:=StrToInt(Edit5.Text);
    workquery.ParamByName('newklient_fk').AsInteger:=StrToInt(Edit6.Text);
 
workquery.ParamByName('fio').AsString:=IBQuery.FieldByName('FIO').AsString;
workquery.ParamByName('ADRES').AsString:=IBQuery.FieldByName('ADRES').AsString;
workquery.ParamByName('TELEPHONE').AsInteger:=IBQuery.FieldByName('TELEPHONE').AsInteger;
workquery.ParamByName('klient_id').AsInteger:=IBQuery.FieldByName('klient_id').AsInteger;
workquery.ParamByName('klient_pk').AsInteger:=IBQuery.FieldByName('klient_pk').AsInteger;
workquery.ParamByName('klient_fk').AsInteger:=IBQuery.FieldByName('klient_fk').AsInteger;
 
    try
      workquery.ExecSQL;
      workquery.Transaction.Commit;
      IBQuery.Open;
    except
      showmessage('ошибка операции обновления’);
    end;
  end;
end;
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
procedure TForm1.BtDeleteClickClick(Sender: TObject);
begin
  with DataModule2 do
  begin
    workquery.SQL.Clear;
    workquery.SQL.Add('delete from klient ');
    workquery.SQL.Add('WHERE (fio=:newfio) and (TELEPHONE=:newtelephone) and (ADRES=:newadres) and (KLIENT_ID=:newklient_id) and (KLIENT_PK=:newklient_pk) and (KLIENT_FK=:newklient_fk)');
 
    workquery.ParamByName('fio').AsString:=IBQuery.FieldByName('fio').AsString;
    workquery.ParamByName('ADRES').AsString:=IBQuery.FieldByName('ADRES').AsString;
    workquery.ParamByName('TELEPHONE').AsInteger:=IBQuery.FieldByName('TELEPHONE').AsInteger;
    workquery.ParamByName('klient_id').AsInteger:=IBQuery.FieldByName('klient_id').AsInteger;
    workquery.ParamByName('klient_pk').AsInteger:=IBQuery.FieldByName('klient_pk').AsInteger;
    workquery.ParamByName('klient_fk').AsInteger:=IBQuery.FieldByName('klient_fk').AsInteger;
 
    workquery.ExecSQL;
    workquery.Transaction.Commit;
    IBQuery.Open;
 
  end;
 
end;
interbase 6.5,delphi 7
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.12.2011, 18:39
Ответы с готовыми решениями:

Не обновляется dbgrid после добавления или удаления записи
procedure TAddDealer.OKBtnClick(Sender: TObject); begin DataModule2.ADOdealers.Append; ...

Кнопка добавления, удаления и отмены записи в таблицу Парадокса
Здравствйте. Нашел для кнопки добавления записей в таблицу метод locate: procedure TAdm.Button1Click(Sender: TObject); begin if ...

Методы добавления и удаления
Здравствуйте, помогите реализовать методы для добавления и удаления клиента, посления и комнаты в базу данных файл connect.py #...

9
1263 / 706 / 62
Регистрация: 21.12.2009
Сообщений: 2,256
05.12.2011, 19:34
Цитата Сообщение от alex_ Посмотреть сообщение
сделал по примеру,даже пустую базу создал с одной таблице но запросы не работают
Какие получаете сообщения?
Цитата Сообщение от alex_ Посмотреть сообщение
interbase 6.5
Это давно уже не сервер БД, а труп, который по непонятным причинам забыли похоронить. Если вы начинаете то лучше скачайте и установитн последнюю версию FireBird
0
 Аватар для albor
504 / 106 / 16
Регистрация: 01.12.2011
Сообщений: 399
05.12.2011, 21:27
А что за IBQuery Вы все время открываете? Это типа Refresh?
0
4 / 4 / 1
Регистрация: 03.06.2011
Сообщений: 35
06.12.2011, 08:53  [ТС]
да это refresh

Добавлено через 19 минут
тыкните на проверенное рук-во
Цитата Сообщение от SAMZ Посмотреть сообщение
Это давно уже не сервер БД, а труп, который по непонятным причинам забыли похоронить. Если вы начинаете то лучше скачайте и установитн последнюю версию FireBird
а бы тоже был бы рад но наш препод работает только с interbase
0
1263 / 706 / 62
Регистрация: 21.12.2009
Сообщений: 2,256
06.12.2011, 08:55
Цитата Сообщение от alex_ Посмотреть сообщение
наш препод работает только с interbase
В утиль такого препода, на переработку!
0
 Аватар для albor
504 / 106 / 16
Регистрация: 01.12.2011
Сообщений: 399
06.12.2011, 09:00
Цитата Сообщение от alex_ Посмотреть сообщение
да это refresh

Добавлено через 19 минут
тыкните на проверенное рук-во

а бы тоже был бы рад но наш препод работает только с interbase
А как Вы узнаете что у Вас что-то не работает? Сообщения об ошибках, просмотр данных в броусере?
0
4 / 4 / 1
Регистрация: 03.06.2011
Сообщений: 35
06.12.2011, 09:36  [ТС]
тыкните на проверенное рук-во
Цитата Сообщение от SAMZ Посмотреть сообщение
Это давно уже не сервер БД, а труп, который по непонятным причинам забыли похоронить. Если вы начинаете то лучше скачайте и установитн последнюю версию FireBird
а бы тоже был бы рад но наш препод работает только с interbase
0
 Аватар для Африканыч
7 / 7 / 1
Регистрация: 25.11.2011
Сообщений: 40
06.12.2011, 10:50
В первом запросе между скобкой и VALUES не стоит пробел. У меня так тоже не работало.
Во втором не худо бы между условиями в WHERE ставить либо and, либо or.
Во втором и третьем в самих условиях вместо Ваших := должно стоять просто =.
0
4 / 4 / 1
Регистрация: 03.06.2011
Сообщений: 35
06.12.2011, 17:14  [ТС]
Delphi
1
2
3
4
5
6
7
8
9
    try // procedure TForm1.Button2Click(Sender: TObject); в кнопке добавить
      workquery.ExecSQL;
      workquery.Transaction.Commit;
      IBQuery.Open;
    except
      showmessage('ошибка операции обновления’);//[Error] Unit1.pas(134): Unterminated string
    end;//[Error] Unit1.pas(135): ')' expected but 'END' found
  end;
end;

Delphi
1
2
3
4
5
6
workquery.ParamByName('fio').AsString:=IBQuery.FieldByName('FIO').AsString;
workquery.ParamByName('ADRES').AsString:=IBQuery.FieldByName('ADRES').AsString;
workquery.ParamByName('TELEPHONE').AsInteger:=IBQuery.FieldByName('TELEPHONE').AsInteger;
workquery.ParamByName('klient_id').AsInteger:=IBQuery.FieldByName('klient_id').AsInteger;
workquery.ParamByName('klient_pk').AsInteger:=IBQuery.FieldByName('klient_pk').AsInteger;
workquery.ParamByName('klient_fk').AsInteger:=IBQuery.FieldByName('klient_fk').AsInteger;
во всех Incompatible types: 'String' and 'Integer'

Добавлено через 14 минут
Project subd.exe raised exception class EIBClientError with message 'Data base not assigned'.

Delphi
1
2
3
4
5
   try//procedure TForm1.BtAddClickClick(Sender: TObject);
        workquery.ExecSQL;
    workquery.Transaction.Commit;// вот здесь
    IBQuery.Open;
    Except
Добавлено через 8 минут
Delphi
1
edit6.Text:=inttostr(IBQuery.FieldByName('klient_fk').AsInteger);
это нормально?
0
 Аватар для albor
504 / 106 / 16
Регистрация: 01.12.2011
Сообщений: 399
06.12.2011, 18:51
Delphi
1
2
showmessage('ошибка операции обновления’);//[Error] Unit1.pas(134): Unterminated string
    end;//[Error] Unit1.pas(135): ')' expected but 'END' found
Кавычки проверьте, должно быть : 'ошибка операции обновления' У Вас в конце левая кавычка.

Delphi
1
2
3
4
workquery.ParamByName('fio').Value := IBQuery.FieldByName('FIO').AsString;
...
workquery.ParamByName('TELEPHONE').Value := IBQuery.FieldByName('TELEPHONE').AsInteger;
...
Так лучше будет. Пусть сам разбирается где у него какой тип..

Delphi
1
2
3
4
5
6
7
 
try  //procedure TForm1.BtAddClickClick(Sender: TObject);
  workquery.ExecSQL;
  workquery.Transaction.Commit;// вот здесь
  IBQuery.Open;
Except
...
Проверьте Workquery.Database
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.12.2011, 18:51
Помогаю со студенческими работами здесь

корзина удаления и добавления
подскажите как реализовать, в корзине есть кнопка добавить товар при нажатии на неё, записывается массив данных в localStorage, товар...

Методы добавления, удаления объекта
Делал по примеру, ошибки разгребаю по мере появления. Помогите, пожалуйста, реализовать методы добавления addBus() и удаления delBus()...

Стеки, функции добавления и удаления элементов
Программа на стеки выводит на экран 9876543210 ..помогите сделать так, чтобы можно было вводить вручную, удалять элементы из стека,...

Добавить функцию добавления и удаления студента
Дана программа на С#, нужно в нее добавить функцию добавления студента add и функцию удаления студента remove. Просмотрел куча...

Написал программу добавления и удаления фигур
НО НЕМОГУ РАЗОБРАТЬСЯ В ОДНОМ.ВСЮ ГОЛОВУ СЛОМАЛ.Как сделать так чтобы фигуры при добавлении ещё и ДВИГАЛИСЬ.Пробовал задавать Timer но...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru