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

在创建sqlite3表后,将ON DELETE CASCADE行为添加到其中

发布时间:2020-12-12 18:55:14 所属栏目:百科 来源:网络整理
导读:是否可以在创建表后将ON DELETE CASCADE添加到表中? 我的架构如下: CREATE TABLE技能(名称varchar,技能varchar,级别int,外键(名称)引用运行程序(名称),主键(名称,技能)); 如果删除了外键,我想级联. 解决方法 SQLite的 ALTER TABLE command无法做到你想要的
是否可以在创建表后将ON DELETE CASCADE添加到表中?

我的架构如下:

CREATE TABLE技能(名称varchar,技能varchar,级别int,外键(名称)引用运行程序(名称),主键(名称,技能));

如果删除了外键,我想级联.

解决方法

SQLite的 ALTER TABLE command无法做到你想要的.

但是,可以绕过SQL解释器并直接更改内部表定义.
SQLite将表定义存储为其sqlite_master table中CREATE TABLE命令的文本副本;看看这个查询的结果:

SELECT sql FROM sqlite_master WHERE type='table' AND name='skills';

将您的级联规范添加到该字符串,然后使用PRAGMA writable_schema=1;启用对sqlite_master的写访问权限并将新表定义写入其中:

UPDATE sqlite_master SET sql='...' WHERE type='table' AND name='skills';

然后重新打开数据库.

警告:这仅适用于不更改表的磁盘格式的更改.如果您确实进行了任何更改记录格式的更改(例如添加/删除字段或修改rowid),您的数据库将会爆炸性地爆炸.

(编辑:李大同)

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

    推荐文章
      热点阅读