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

时间:2012-10-31 01:33:50

标签: sqlite ddl

是否可以在创建表后向表中添加ON DELETE CASCADE

我的架构如下:

CREATE TABLE skills(name varchar, skill varchar, level int, foreign key(name) references runners(name), primary key(name, skill));

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

1 个答案:

答案 0 :(得分:6)

SQLite的ALTER TABLE command无法做到你想做的事。

但是,可以绕过SQL解释器并直接更改内部表定义。 SQLite将表定义存储为sqlite_master tableCREATE 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),那么您的数据库将会爆炸性地爆发。