我需要重命名SQLite数据库中一些表中的一些列。 我知道以前有人在stackoverflow上问过类似的问题,但这是针对一般的SQL,没有提到SQLite的情况。
从ALTER TABLE的SQLite文档中,我收集到不可能“轻松”地做这样的事情(即一个ALTER TABLE语句)。
我想知道有人知道一个通用的SQL方法做这样的事情与SQLite。
我需要重命名SQLite数据库中一些表中的一些列。 我知道以前有人在stackoverflow上问过类似的问题,但这是针对一般的SQL,没有提到SQLite的情况。
从ALTER TABLE的SQLite文档中,我收集到不可能“轻松”地做这样的事情(即一个ALTER TABLE语句)。
我想知道有人知道一个通用的SQL方法做这样的事情与SQLite。
当前回答
创建一个具有所需列名的新列:COLNew。
ALTER TABLE {tableName} ADD COLUMN COLNew {type};
将旧列COLOld的内容复制到新列COLNew。
INSERT INTO {tableName} (COLNew) SELECT {COLOld} FROM {tableName}
注:以上一行必须使用括号。
其他回答
案例1:SQLite 3.25.0+
只有SQLite的3.25.0版本支持重命名列。如果你的设备满足这个要求,事情就很简单了。下面的查询可以解决你的问题:
ALTER TABLE "MyTable" RENAME COLUMN "OldColumn" TO "NewColumn";
案例2:SQLite旧版本
你必须遵循不同的方法来得到结果,这可能有点棘手
例如,如果你有一个这样的表:
CREATE TABLE student(Name TEXT, Department TEXT, Location TEXT)
如果您希望更改列Location的名称
步骤1:重命名原始表:
ALTER TABLE student RENAME TO student_temp;
步骤2:现在用正确的列名创建一个新表student:
CREATE TABLE student(Name TEXT, Department TEXT, Address TEXT)
步骤3:将原表中的数据复制到新表中:
INSERT INTO student(Name, Department, Address) SELECT Name, Department, Location FROM student_temp;
注意:上面的命令应该是一行。
步骤4:删除原来的表:
DROP TABLE student_temp;
通过这四个步骤,您可以手动更改任何SQLite表。 请记住,您还需要在新表上重新创建索引、查看器或触发器。
Sqlite3 yourdb .dump > /tmp/db.txt 编辑/tmp/db.txt修改创建行的列名 Sqlite2 yourdb2 < /tmp/db.txt Mv /move yourdb2 yourdb
自版本2018-09-15 (3.25.0) Sqlite支持重命名列
https://sqlite.org/changes.html
最近我不得不在SQLite3中使用一个名为points的表,列为id lon lat。错误地,当导入表时,latitude的值存储在lon列中,反之亦然,因此一个明显的修复方法是重命名这些列。所以窍门是:
create table points_tmp as select id, lon as lat, lat as lon from points;
drop table points;
alter table points_tmp rename to points;
我希望这对你有用!
引用sqlite文档:
SQLite支持的有限子集 ALTER TABLE。ALTER TABLE命令 在SQLite中允许用户重命名 表或添加新列到 现有的表。不能重命名列、删除列或从表中添加或删除约束。
当然,您可以用新的布局创建一个新表,SELECT * FROM old_table,并用您将收到的值填充新表。