加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 19:08:55 所属栏目:百科 来源:网络整理
导读:我多次检查了功能列表,似乎级联应该可以工作. 当我执行这个 python脚本时: #!/usr/bin/env python3import sqlite3print(sqlite3.sqlite_version)con = sqlite3.connect(':memory:')a = "create table a (id integer primary key,name text)"con.execute(a)b
我多次检查了功能列表,似乎级联应该可以工作.
当我执行这个 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”)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读