标签:sqlite table-rename sql android
我有一个名为groups的表,并且我想重命名其列之一.到目前为止还可以.我知道sqlite不支持重命名列,所以我做到了:
ALTER TABLE groups RENAME to tmp_groups;
CREATE TABLE groups(
_ID integer primary key autoincrement,
new_column_name integer
);
INSERT INTO groups(_ID, new_column_name) SELECT _ID, old_column_name FROM tmp_groups;
DROP TABLE tmp_groups;
但是,当我删除表tmp_groups时,具有带有ON DELETE CASCADE的外键的表成员也将其记录删除,因此我必须执行以下操作:
>创建一个表tmp_members,该表具有与member相同的列,并且没有外键;
>将来自成员的记录插入tmp_members;
>删除表成员;
>从第一部分运行代码(带有groups表);
>用其外键重新创建表成员;
>从tmp_members插入成员数据;
伙计,那很累!它的代码太多,无法简单地重命名列.
有没有更简单的方法来处理此约束问题,或者这是“ sqlite方法”?
解决方法:
由于历史原因,SQLite允许禁用外键约束(这甚至是当前的默认设置).
在执行groups表之前,只需运行PRAGMA foreign_keys = off.
也可以通过使用PRAGMA writable_schema重命名列,但是只有在知道自己在做什么的情况下才应该这样做.
标签:sqlite,table-rename,sql,android 来源: https://codeday.me/bug/20191121/2051183.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。