|
0 / 0 / 0
Регистрация: 19.04.2015
Сообщений: 18
|
|||||||||||
При удалении одной строки в таблице удаляются все записи29.04.2015, 23:57. Показов 2654. Ответов 8
Метки нет (Все метки)
Всем доброго времени суток. В процессе написания оболочки на С++ builder под базу Firebird возникла такая ситуация: в базе две таблицы - главная (список клиентов) и зависимая (список выездов к каждому клиенту), таблицы соединены между собой по полю наименования клиентов и имеется ограничение в виде каскадного удаления записей. То есть, при удалении строки с клиентом в главной таблице одновременно удаляются и все связанные с ним выезды в подчиненной. Это реализовано в оболочке и работает нормально. Теперь обратная ситуация: нужно из подчиненной таблицы удалить одну запись (например сделана неверная запись). Нажимаем кнопку "Удалить", следует запрос на удаление текущей записи, запись удаляется и... вместе с ней удаляются и все записи, относящиеся к текущему клиенту... Вот в чем проблема? Абсолютно точно, что не в самой базе (пробовал удалять через программу IBExpert, там все работает нормально, значит проблема где-то здесь в коде). Итак - запрос SQL на удаление:
0
|
|||||||||||
| 29.04.2015, 23:57 | |
|
Ответы с готовыми решениями:
8
Дублирование данных в запросе: при удалении одной записи удаляются многие При удалении записи в дочерней таблице она пытается удалить запись в родительской. Как перебрать все строки ListView в цикле, если при этом некоторые строки удаляются? |
| 30.04.2015, 03:44 | |||||||||
Сообщение было отмечено alex022 как решение
РешениеСделай во 2 таблице уникальное поле (числовое с генератором), которое идентифицирует каждую запись и удаляй по нему. Что я этим хотел сказать
1
|
|||||||||
|
0 / 0 / 0
Регистрация: 19.04.2015
Сообщений: 18
|
||
| 30.04.2015, 11:11 [ТС] | ||
|
0
|
||
|
0 / 0 / 0
Регистрация: 19.04.2015
Сообщений: 18
|
|
| 04.05.2015, 17:47 [ТС] | |
|
В общем разобрался. Сделал так, как и говорили: то есть добавил поле Id, соответственно ему SQL запрос, и все пошло как надо. Но возникли новые вопросы:
1. Теперь невозможно добавить новую запись. Вылетает исключение, что поле Id не может быть пустым. Но я и не назначал запрет на пустое поле, напротив - пользователь НЕ должен это поле видеть, оно заполняется автоматически, по соответствующему генератору (кстати, оно действительно заполняется). 2. Если из таблицы удалить все данные, то новое Id начинается не с 1, а с того значения на котором остановились в последний раз (к примеру: было в таблице 10 записей, все удалили - новая запись получит Id не 1, как было бы логично в пустой таблице, а 11). Как это все поправить? Заранее благодарен...
0
|
|
| 05.05.2015, 03:25 | |||
|
1
|
|||
|
0 / 0 / 0
Регистрация: 19.04.2015
Сообщений: 18
|
|
| 05.05.2015, 09:11 [ТС] | |
|
В первом случае уже разобрался - просто не посмотрел, что стоит метка на NOT NULL, которую я изначально выставил и забыл убрать. Так что теперь все работает нормально.
Ну, а во втором - значит пусть тогда так и остается. Я с чего-то решил, что это работает неправильно. В таком случае, работу над программой можно считать практически завершенной. Осталось пару косяков еще поправить, но там мне уже все ясно
0
|
|
|
0 / 0 / 0
Регистрация: 19.04.2015
Сообщений: 18
|
|
| 05.05.2015, 10:35 [ТС] | |
|
Хорошо, посмотрю и этот вариант. Работаю через IBDataSet.
0
|
|
| 05.05.2015, 11:48 | ||
|
1
|
||
| 05.05.2015, 11:48 | |
|
Помогаю со студенческими работами здесь
9
Элементы не удаляются из ListWidget-а при удалении их из контейнера При удалении учащихся из журнала удаляет все связанные записи с ним в остальных таблицах
БД sqlite. При удалении элемента из родительской таблицы, не удаляются элементы из дочерних таблиц Пересчет цены за все услуги при удалении строки табличной части документа. Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html
Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
|
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
|
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях.
Задача: при копировании документа очищать определенные реквизиты и табличную. . .
|