cascade sqlite 数据库_如何使ON DELETE CASCADE在sqlite 3.7.4中工作?

我多次检查了功能列表,似乎级联应该可以工作.

当我执行这个

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)]

[]

这证明级联没有发生.我做错了什么或者获得与级联相同结果的解决方案是什么?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值