我的架构如下:
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),您的数据库将会爆炸性地爆炸.
总结以上是内存溢出为你收集整理的在创建sqlite3表后,将ON DELETE CASCADE行为添加到其中全部内容,希望文章能够帮你解决在创建sqlite3表后,将ON DELETE CASCADE行为添加到其中所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)