微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

android – SQLite使用默认值添加列

我在Android sqlite DB中工作.我正在将它从版本1升级到版本2.
onUpgrade方法按预期调用.

我的代码

sqliteDatabase.execsql("ALTER TABLE " + Contracts.DateActivities.TABLE_NAME + " ADD COLUMN " + Contracts.DateActivities.C_GROUP + " INTEGER DEFAULT 0;");

我一直得到同样的错误

Caused by: android.database.sqlite.sqliteException: near "group": Syntax error (code 1):,while compiling: ALTER TABLE DateActivities ADD group INTEGER DEFAULT 0

我究竟做错了什么?

我试过的其他变化:

sqliteDatabase.execsql("ALTER TABLE " + Contracts.DateActivities.TABLE_NAME + " ADD COLUMN " + Contracts.DateActivities.C_GROUP + " INTEGER DEFAULT 0;");
sqliteDatabase.execsql("ALTER TABLE " + Contracts.DateActivities.TABLE_NAME + " ADD COLUMN " + Contracts.DateActivities.C_GROUP + " int DEFAULT 0;");
sqliteDatabase.execsql("ALTER TABLE " + Contracts.DateActivities.TABLE_NAME + " ADD " + Contracts.DateActivities.C_GROUP + " INTEGER DEFAULT 0;");
最佳答案
我怀疑Contracts.DateActivities.C_GROUP是“GROUP”(或“组”或“组”或……大小写无关紧要),这是sqlite的保留关键字…并且不能用于列名

原文地址:https://www.jb51.cc/android/431017.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐