android-当其他表具有外键时,在sqlite中更改列名

android-当其他表具有外键时,在sqlite中更改列名,第1张

概述我有一个名为groups的表,并且我想重命名其列之一.到目前为止还可以.我知道sqlite不支持重命名列,所以我做到了:ALTERTABLEgroupsRENAMEtotmp_groups;CREATETABLEgroups(_IDintegerprimarykeyautoincrement,new_column_nameinteger);INSERTINTOgroups

我有一个名为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重命名列,但是只有在知道自己在做什么的情况下才应该这样做.

总结

以上是内存溢出为你收集整理的android-当其他表具有外键时,在sqlite中更改列名全部内容,希望文章能够帮你解决android-当其他表具有外键时,在sqlite中更改列名所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1077898.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-27
下一篇 2022-05-27

发表评论

登录后才能评论

评论列表(0条)

保存