Как заставить ON DELETE CASCADE работать в sqlite 3.7.4? - PullRequest
8 голосов
/ 18 декабря 2010

Я проверил список возможностей несколько раз, и похоже, что каскадирование должно работать Когда я выполняю этот скрипт Python:

#!/usr/bin/env python3
import sqlite3

print(sqlite3.sqlite_version)

con = sqlite3.connect(':memory:')

a = "create table a (id integer primary key, name text)"
con.execute(a)

b = "create table b (id integer primary key, r integer, foreign key(r) references a(id) on delete cascade)"
con.execute(b)
con.commit()

a = "insert into a (name) values (\"abc\")"
con.execute(a)
con.commit()

print(con.execute("select * from a").fetchall())

a = "insert into b (r) values (1)"
con.execute(a)
con.commit()

print(con.execute("select * from b").fetchall())

a = "delete from a where id=1"
con.execute(a)
con.commit()

print(con.execute("select * from b").fetchall())
print(con.execute("select * from a").fetchall())

Я получаю эти результаты:

3.7.4
[(1, 'abc')]
[(1, 1)]
[(1, 1)]
[]

Что доказывает, что каскад не произошел. Что я сделал не так или какие решения позволяют получить тот же результат, что и каскадирование?

Ответы [ 2 ]

9 голосов
/ 18 декабря 2010

Внешние ключи SQLite отключены в целях совместимости. Вам необходимо включить их вручную сразу после каждого подключения к базе данных.

con.execute("PRAGMA foreign_keys = ON")

2 голосов
/ 17 мая 2012

Пользователь получит лучший ответ Thibault J в этом вопросе: Включить проверку целостности с помощью sqlite в django , который говорит:

from django.db.backends.signals import connection_created
def activate_foreign_keys(sender, connection, **kwargs):
    """Enable integrity constraint with sqlite."""
    if connection.vendor == 'sqlite':
        cursor = connection.cursor()
        cursor.execute('PRAGMA foreign_keys = ON;')

connection_created.connect(activate_foreign_keys)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...