首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >sqlite语句坏MOJO

sqlite语句坏MOJO
EN

Stack Overflow用户
提问于 2012-10-16 12:22:36
回答 1查看 106关注 0票数 0

我有一个简单的问题,可能有一个简单的解决方案,但这个解决方案暗示了我.所以我有一个简单的表,即phone,它有4列,我想添加一个新列。由于SQLite不修改表,所以我必须删除并创建。

phone_old

_id整数主键自动增量,

名称文本不为空,

值文本

phone

_id整数主键自动增量,

名称文本不为空,

itemState文本不为空,

值文本

因此,我做了以下工作: 1.重命名旧表,2.创建带有额外字段(在我的例子中是itemState)的新表,并选择并插入定义itemstate默认值的所有内容。

代码语言:javascript
复制
1 ALTER TABLE Phone RENAME TO Phone_OLD;

2 CREATE table Phone(
_id integer primary key autoincrement, 
name text not null, 
itemState text not null, 
value text ); 

3) INSERT INTO Phone SELECT * , 'Synced' as itemState from Phone_OLD where Phone_OLD. ;

结果是项目状态(同步)作为最后一个字段添加,而不是在第3列(即itemState )中添加。

因此,列名不对应于行值,这意味着项目状态是在末尾添加的(作为行中的最后一列,而不是应该作为位置3)。

仅仅将itemstate放在末尾就可以解决问题,但是由于生成了表创建语句,我必须重写大量代码才能做到这一点,而且这组查询返回废话使我感到恼火。

有什么想法吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-10-16 12:39:51

Sqlite确实支持附加列。

代码语言:javascript
复制
 ALTER TABLE Phone ADD COLUMN [itemState] text not null default ''
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12914629

复制
相关文章

相似问题

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