Форум программистов, компьютерный форум, киберфорум
SQLite
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.53/15: Рейтинг темы: голосов - 15, средняя оценка - 4.53
0 / 0 / 0
Регистрация: 25.02.2011
Сообщений: 5

БД sqlite. При удалении элемента из родительской таблицы, не удаляются элементы из дочерних таблиц

24.01.2013, 10:48. Показов 3035. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, уважаемые форумчане!

Есть три таблицы связанные между собой, ниже скрипты создания этих таблиц (кусок скрипта в lua):

Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
CreateClassificators = ""
    .."    CREATE TABLE  IF NOT EXISTS CLASSIFICATORS ("
    .."      [CL_ID] INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT UNIQUE,"
    .."      [CL_NAME] TEXT, "
    .."      [CL_FOREIGN_OWNER] INTEGER);",
    CreateTrees = ""
    .."   CREATE TABLE IF NOT EXISTS TREES ("
    .."    [TREE_ID] INTEGER NOT NULL PRIMARY KEY ON CONFLICT ROLLBACK AUTOINCREMENT CONSTRAINT [PART] UNIQUE ON CONFLICT ROLLBACK,    "
    .."    [CL_ID] INTEGER CONSTRAINT [FK_TREES_REFERENCE_CLASSIFICATORS] REFERENCES [CLASSIFICATORS]([CL_ID]) ON DELETE CASCADE ON UPDATE CASCADE,"
    .."    [PARENT_TREE_ID] INTEGER, "
    .."    [TREE_NAME] TEXT, "
    .."    [DATE_OF_CREATION] DATA, "
    .."    [EXTERNAL_ID] INTEGER, " 
    .."    [TREE_CHANGEABLE] INTEGER, " 
    .."    [SIGNATURE_STAMP] INTEGER, " 
    .."    [TYPE_ID] INTEGER, " 
    .."    [TREE_PROPERTIES_ID] INTEGER, " 
    .."    [CLOSED] INTEGER);", 
    CreateAccords = ""
    .."    CREATE TABLE  IF NOT EXISTS ACCORDS ("
    .."    [AC_ID] INTEGER NOT NULL PRIMARY KEY ON CONFLICT ROLLBACK AUTOINCREMENT,  "
    .."    [DOC_ID] INTEGER NOT NULL CONSTRAINT [FK_ACCORDS_REFERENCE_DOCUMENTS] REFERENCES [DOCUMENTS]([DOC_ID]) ON DELETE CASCADE ON UPDATE CASCADE,"
        .."    [TREE_ID] INTEGER NOT NULL CONSTRAINT [FK_ACCORDS_REFERENCE_TREES] REFERENCES [TREES]([TREE_ID]) ON DELETE CASCADE ON UPDATE CASCADE);",
Таблицы связаны между собой - CLASSIFICATORS - Родительская таблица
связана с дочерней TREES, через CL_ID
а TREES в свою очередь связана с дочерней ACCORD, через TREE_ID


добавляю в эти таблицы связанные элементы
удаляю элемент из CLASSIFICATOR двумя способами:
1) через выполнение запроса из скрипта Lua
DELETE FROM CLASSIFICATORS WHERE CL_ID = :CL_ID;

в резьтате удаляется элемент из таблицы CLASSIFICATOR, НО СВЯЗАННЫЕ С НИМ ЭЛЕМЕНТЫ ИЗ ДОЧЕРНИХ ТАБЛИЦ (TREES, ACCORDS)НЕ УДАЛЯЮТСЯ

2) через СУБД sqllite
в результате получаю ошибку: "foreign key mismatch"


Кто-нибудь сталкивался с этой проблемой? Подскажите, пожалуйста, решение.
Буду очень признателен...
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.01.2013, 10:48
Ответы с готовыми решениями:

Элементы не удаляются из ListWidget-а при удалении их из контейнера
Надо,чтобы из списка удалялись элементы.Я вроде бы удаляю их из контейнера,но из листвиджета не удаляются.

При выборе элемента из любой таблицы нужно, чтоб отображались элементы из 2 других таблиц
При выборе элемента из любой таблицы нужно, чтоб отображались элементы из 2 других таблиц. Например: из пример => метод, тип задачи....

Значение Null при удалении родительской записи
Добрый день. Есть две таблицы Customers и Orders. В Orders есть ссылка (FK) на таблицу с клиентами customer_id. Как при удалении клиента в...

2
1234 / 424 / 107
Регистрация: 31.03.2012
Сообщений: 1,159
26.01.2013, 10:04
Цитата Сообщение от nvrrus Посмотреть сообщение
CreateAccords = "" .." CREATE TABLE IF NOT EXISTS ACCORDS (" .." [AC_ID] INTEGER NOT NULL PRIMARY KEY ON CONFLICT ROLLBACK AUTOINCREMENT, " .." [DOC_ID] INTEGER NOT NULL CONSTRAINT [FK_ACCORDS_REFERENCE_DOCUMENTS] REFERENCES [DOCUMENTS]([DOC_ID]) ON DELETE CASCADE ON UPDATE CASCADE," .." [TREE_ID] INTEGER NOT NULL CONSTRAINT [FK_ACCORDS_REFERENCE_TREES] REFERENCES [TREES]([TREE_ID]) ON DELETE CASCADE ON UPDATE CASCADE);",
у тебя есть еще ссылка на таблицу [DOCUMENTS], поэтому воспроизвести не получилось. Но вот скрипт в точности выполняет задуманное, только немножко переделал таблицы, но это не существенно
Кликните здесь для просмотра всего текста
SQL
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
DROP TABLE IF EXISTS tmain;
DROP TABLE IF EXISTS tsub;
DROP TABLE IF EXISTS tsubsub;
    
CREATE TABLE tmain(
  id INTEGER PRIMARY KEY autoincrement,
  m_text text);
CREATE TABLE tsub(
  id_sub INTEGER PRIMARY KEY ON conflict ROLLBACK autoincrement CONSTRAINT part UNIQUE ON conflict IGNORE,
  id_tmain INTEGER REFERENCES tmain(id) ON DELETE cascade ON UPDATE cascade);
CREATE TABLE  tsubsub(
  id INTEGER NOT NULL PRIMARY KEY ON conflict ROLLBACK autoincrement,
  id_sub INTEGER NOT NULL REFERENCES tsub(id_sub) ON DELETE cascade ON UPDATE cascade);
 
-- INSERT INTO tmain (всего ключей - 3! с большим значением в связанную таблицу не добавиться!
INSERT INTO tmain(m_text) VALUES ("id(1)");
INSERT INTO tmain(m_text) VALUES ("for delete id(2)");
INSERT INTO tmain(m_text) VALUES ("id(3) - all sub keys is null");
 
-- INSERT INTO tsub - (всего ключей - 9)
INSERT INTO tsub(id_tmain) VALUES (1);  -- id_sub(1)
INSERT INTO tsub(id_tmain) VALUES (2)-- id_sub(2) - будет удалено 
INSERT INTO tsub(id_tmain) VALUES (1)-- id_sub(3)
INSERT INTO tsub(id_tmain) VALUES (2)-- id_sub(4) - будет удалено 
INSERT INTO tsub(id_tmain) VALUES (2)-- id_sub(5) - будет удалено 
INSERT INTO tsub(id_tmain) VALUES (2)-- id_sub(6) - будет удалено 
INSERT INTO tsub(id_tmain) VALUES (1)-- id_sub(7)
INSERT INTO tsub(id_tmain) VALUES (2)-- id_sub(8) - будет удалено 
INSERT INTO tsub(id_tmain) VALUES (1)-- id_sub(9)
 
 
-- INSERT INTO tsubsub (БУДУТ УДАЛЕНЫ sub_id из набора [2,4,5,6,8]
INSERT INTO tsubsub(id_sub) VALUES (1);
INSERT INTO tsubsub(id_sub) VALUES (2);
INSERT INTO tsubsub(id_sub) VALUES (3);
INSERT INTO tsubsub(id_sub) VALUES (4);
INSERT INTO tsubsub(id_sub) VALUES (4);
INSERT INTO tsubsub(id_sub) VALUES (6);
INSERT INTO tsubsub(id_sub) VALUES (3);
INSERT INTO tsubsub(id_sub) VALUES (7);
INSERT INTO tsubsub(id_sub) VALUES (2);
INSERT INTO tsubsub(id_sub) VALUES (8);
INSERT INTO tsubsub(id_sub) VALUES (2);
INSERT INTO tsubsub(id_sub) VALUES (2);
INSERT INTO tsubsub(id_sub) VALUES (2);
INSERT INTO tsubsub(id_sub) VALUES (3);
INSERT INTO tsubsub(id_sub) VALUES (7);
INSERT INTO tsubsub(id_sub) VALUES (5);
INSERT INTO tsubsub(id_sub) VALUES (5);
INSERT INTO tsubsub(id_sub) VALUES (6);
INSERT INTO tsubsub(id_sub) VALUES (5);
INSERT INTO tsubsub(id_sub) VALUES (5);
INSERT INTO tsubsub(id_sub) VALUES (3);
INSERT INTO tsubsub(id_sub) VALUES (3);
INSERT INTO tsubsub(id_sub) VALUES (1);
INSERT INTO tsubsub(id_sub) VALUES (2);
INSERT INTO tsubsub(id_sub) VALUES (1);
 
-- со связкой
SELECT * FROM tmain m 
    LEFT JOIN tsub s ON m.id = s.id_tmain
    LEFT JOIN tsubsub ss ON s.id_sub = ss.id_sub;
 
-- Удаление!
DELETE FROM tmain WHERE id=2;
 
-- со связкой
SELECT * FROM tmain m 
    LEFT JOIN tsub s ON m.id = s.id_tmain
    LEFT JOIN tsubsub ss ON s.id_sub = ss.id_sub;
Если нужно могу привести это же и на lua.

Не по теме:

я использую свою сборку библиотеки для lua и с ней тоже проверял, но чтобы удостоверится в работе скрипта с официальной сборкой, мне нужно будет ее закачать :(

0
0 / 0 / 0
Регистрация: 25.02.2011
Сообщений: 5
26.01.2013, 19:57  [ТС]
Joeymax, большое спасибо за очень серьезный подход к делу!

Я ваше сообщение увидел только сегодня.

А вчера с другого форума ответили - и помогло следующее:

До создания таблиц, выполняю

Code
1
db:exec("PRAGMA foreign_keys = ON;")
и перед удалением из родительской таблицы

Code
1
2
3
db:exec("PRAGMA foreign_keys = ON;")
 
ExecuteTransactionSQL("DELETE FROM CLASSIFICATOR WHERE CL_ID = '1';")
в это случае дочерние элементы удаляются!

еще раз спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
26.01.2013, 19:57
Помогаю со студенческими работами здесь

Не удаляются данные из таблицы связи многие ко многим из БД SQLite
Добрый день, подскажите пожалуйста: Имеется проект C# приложение windows form с entity framework code first на борту. С начала entity...

Как при изменение размера родительской формы, изменить размеры дочерних форм?
Есть одна родительская и две дочерние формы, как сделать так, что при переводе родительской формы в полноэкранный режим, одна из форм...

При удалении записи в дочерней таблице она пытается удалить запись в родительской.
MSSQL 7.0. Две таблицы - родительская и дочерняя. Естественно стоят ограничения PK и FK(внешний ключ). Если в дочерней таблице удаляю...

При удалении одной строки в таблице удаляются все записи
Всем доброго времени суток. В процессе написания оболочки на С++ builder под базу Firebird возникла такая ситуация: в базе две таблицы -...

Дублирование данных в запросе: при удалении одной записи удаляются многие
Здравствуйте уважаемые! Такая проблема у меня, сделал простой запрос из двух таблиц. Поставил фильтры для удобства. И тут...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru