Python 如何在sqlite 3.7.4中进行删除级联工作?

Python 如何在sqlite 3.7.4中进行删除级联工作?,python,sql,sqlite,Python,Sql,Sqlite,我检查了功能列表好几次,似乎级联应该可以工作。 执行此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 pr

我检查了功能列表好几次,似乎级联应该可以工作。 执行此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)]
[]

这证明了级联并没有发生。我做错了什么,或者有什么解决方案可以获得与级联相同的结果

出于兼容性目的,禁用SQLite外键。您需要在每次连接到数据库后立即手动启用它们


con.execute(“PRAGMA foreign\u keys=ON”)

用户在这个问题上有一个更好的答案:上面说:

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)

虽然我删除了我的DB文件,删除了所有以前的迁移,并创建了新的迁移,但这对我来说没有什么不同。未按预期使用“on delete cascade”创建表。我想知道为什么没有发生。