首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >是否可以在创建后将sqlite表中的列更改为AUTOINCREMENT?

是否可以在创建后将sqlite表中的列更改为AUTOINCREMENT?
EN

Stack Overflow用户
提问于 2009-03-10 16:20:13
回答 11查看 60.2K关注 0票数 39

做完表格后可以做一个字段AUTOINCREMENT吗?例如,如果您像这样创建一个表:

代码语言:javascript
复制
create table person(id integer primary key, name text);

然后,后来意识到它需要自动递增。我如何修复它,即在MySQL中你可以这样做:

代码语言:javascript
复制
alter table person modify column id integer auto_increment

创建表是创建列AUTOINCREMENT的唯一机会吗

EN

回答 11

Stack Overflow用户

发布于 2012-05-06 01:35:48

您可以将内容转储到新表中:

代码语言:javascript
复制
CREATE TABLE failed_banks_id (id integer primary key autoincrement, name text, city text, state text, zip integer, acquired_by text, close_date date, updated_date date);

INSERT INTO failed_banks_id(name, city, state, zip, acquired_by,close_date, updated_date)
SELECT name, city, state, zip, acquired_by,close_date, updated_date
FROM failed_banks;

并重命名该表:

代码语言:javascript
复制
DROP TABLE failed_banks;
ALTER TABLE failed_banks_id RENAME TO failed_banks;
票数 47
EN

Stack Overflow用户

发布于 2010-04-26 19:13:12

背景:

新密钥在表中当前的所有密钥中都是唯一的,但它可能与先前从表中删除的密钥重叠。若要创建在表的生存期内唯一的键,请将AUTOINCREMENT关键字添加到整数主键声明中。

http://www.sqlite.org/faq.html#q1

SQLite限制:

SQLite支持ALTER TABLE的有限子集。SQLite中的ALTER table命令允许用户重命名表或向现有表中添加新列。不能重命名列、删除列,也不能在表中添加或删除约束。

http://www.sqlite.org/lang_altertable.html

黑客似乎存在

看起来您可以设置

PRAGMA writable_schema=ON;

然后手动更新sqlite_master表,将"id整数主键“插入到表定义的SQL中。我试过了,它似乎起作用了。但这是危险的。如果你搞砸了,你会破坏数据库文件。

http://www.mail-archive.com/sqlite-users@sqlite.org/msg26987.html

票数 12
EN

Stack Overflow用户

发布于 2009-03-10 16:22:09

SQLite Faq

简而言之:声明为整型主键的列将自动递增

因此,在创建表时,请将该列声明为INTEGER PRIMARY KEY,并且该列将随着每次新插入而自动递增。

或者,您可以在事后使用SQL语句ALTER将列类型更改为整数主键,但是如果您自己创建表,最好在初始creating语句中执行此操作。

票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/631060

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档