python - 如何使 ON DELETE CASCADE 在 sqlite 3.7.4 中工作?

标签 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 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_keys = ON")

关于python - 如何使 ON DELETE CASCADE 在 sqlite 3.7.4 中工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4477269/

相关文章:

python - 又是 : UnicodeEncodeError: ascii codec can't encode

php - 如何通过 php/mysqli 获取行号

c# - OrmLite : SQLiteExceptionSQL logic error or missing database near ")": syntax error

python - django 中的正则表达式不匹配

python - 如何在 Python 中将函数作为函数参数传递

python - 如何减少获取帧时的CPU使用率

sql - SqlConnection 是否并行处理查询?

mysql inner join 给出不好的结果(?)

sqlite - 如何只选择部分 BLOB 列

python - Django/SQLite 用户模型 UNIQUE 约束失败