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的保留关键字…并且不能用于列名

相关文章

Android性能优化——之控件的优化 前面讲了图像的优化,接下...
前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要...
最近项目重构,涉及到了数据库和文件下载,发现GreenDao这个...
WebView加载页面的两种方式 一、加载网络页面 加载网络页面,...
给APP全局设置字体主要分为两个方面来介绍 一、给原生界面设...
前言 最近UI大牛出了一版新的效果图,按照IOS的效果做的,页...