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

Удаление из таблицы "многие ко многим"

21.06.2013, 22:04. Показов 1428. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Такая проблема:
Есть база данных в Access и приложение в Delphi. БД подключена через BDE.
Вот схема:



Меня интересуют таблицы обведенные в красный.
Эти таблицы образуют связь "многие ко многим". Таблицы Dogovor и Uslygi как бы главные, а Dog_Usl хранит их ключи.
Проблема в том, что я пытаюсь сделать через делфи удаление из этой таблицы "многие ко многим", удалять то удаляет, но выдает ошибку - "TDogUsl: DataSet not in edit or insert mode". Я понимаю, что эта ошибка значит и пробовала перевести таблицу в состояние редактирования, но он выдает другую чтото связанное в адресом в самом Access.
Дорогие программисты, помогите пожалуйста, курсовик горит =(
Я честно пыталась сделать что-то, но никак.

Вот код:
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
procedure TFDogovor.BitBtn2Click(Sender: TObject);
var
otvet:integer;
begin
  otvet:= MessageDlg('Âû äåéñòâèòåëüíî õîòèòå óäàëèòü çàïèñü?',mtWarning,[mbYes,mbNo], 0);
  if otvet=mrYes then
  begin
 DM.QDogUsl.DataSource.DataSet.Edit;
 DM.TDogUsl.Delete;
 DM.TDogUsl.FieldByName('Kod_dogovora').AsInteger:=StrtoInt(DBEkod.text);
DM.TDogUsl.Post;
 DM.TDogUsl.FieldByName('Kod_uslygi').AsInteger:=StrToInt(DBEkod2.text);
DM.TDogUsl.Delete;
DM.TDogUsl.Post;
 MessageDlg('Çàïèñü óäàëåíà',mtInformation , [mbOk], 0);
end;
  DM.QDogUsl.Close;
   DM.QDogUsl.SQL.Clear;
   DM.QDogUsl.SQL.Add('SELECT DISTINCT Uslugi.Name');
   DM.QDogUsl.SQL.Add('FROM Uslugi,Dogovor,Dog_Usl');
   DM.QDogUsl.SQL.Add('Where (Dog_Usl.Kod_dogovora='+(DBEkod.Text)+')');
   DM.QDogUsl.SQL.Add('AND (Uslugi.Kod_uslygi=Dog_Usl.Kod_uslygi)');
   DM.QDogUsl.Open;
   DM.QDogUsl.Active:=true;
end;
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.06.2013, 22:04
Ответы с готовыми решениями:

удаление информации из таблицы (связь многие ко многим)
несколько таблиц с различной пронумерованной информацией создают связь многие ко многим. номера соединяются в одной таблице по выбору...

удаление строки из смежной таблицы при обновлении сущности (связь многие ко многим)
реализована связь многие ко многим через доп.таблицу. Вопрос: почему hibernate удаляет из доп.таблицы строки с идентификаторами обновляемой...

Редактирование таблицы Многие ко многим
Всем привет, есть у меня модель public class Lib { public int BookId { get; set; } public Book Book { get;...

2
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
21.06.2013, 22:37
Присвоение значения коду договора и коду услуги совсем уже из области фантазии.
Это не поможет установить курсор на нужные для удаления записи в компоненте и только вредит делу.
Удалять проще через модифицирующий запрос DELETE:
Delphi
1
2
3
query.SQL.Text := 'delete from Dog_Usl where Kod_dogovora = '+DBEkod.text+
                  ' and Kod_uslygi = '+DBEkod2.text;
query.ExecSQL;
1
0 / 0 / 1
Регистрация: 04.05.2012
Сообщений: 21
22.06.2013, 14:34  [ТС]
Цитата Сообщение от Скандербег Посмотреть сообщение
Присвоение значения коду договора и коду услуги совсем уже из области фантазии.
Это не поможет установить курсор на нужные для удаления записи в компоненте и только вредит делу.
Удалять проще через модифицирующий запрос DELETE:
Delphi
1
2
3
query.SQL.Text := 'delete from Dog_Usl where Kod_dogovora = '+DBEkod.text+
                  ' and Kod_uslygi = '+DBEkod2.text;
query.ExecSQL;
Огромное спасибо! Очень выручили =)
Все работает)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.06.2013, 14:34
Помогаю со студенческими работами здесь

Подстановка из таблицы многие-ко-многим
Здравствуйте. Подскажите пожалуйста, как реализовать правильную подстановку. - Есть две таблицы (например Номера классов и Буквы...

Создание таблицы со связью многие-ко-многим
Здравствуйте, помогите разобраться. Возможно ли подключиться таблице(Timetable) к таблице(Group), через табл. многие-ко многим(GroupTT),...

Каскадное удаление данных через связь в БД многие-ко-многим
Создал 2 таблицы, задачи и теги. Для объединения через связь многие-ко-многим использую таблицу TaskTag public class Task { ...

Сохрание промежуточной таблицы связи многие-ко-многим
Всем привет. Проблема следующая Есть две таблицы 1: statia - "родительская", 2: prepodStatia - "связывающая" в данном...

Заполнение таблицы с отношением многие ко многим (EntityFramework)
Всем привет мне нужно к таблице SemesterLessonsPower передать несколько подгруп StudentSubGroup public class SemesterLessonsPower ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru