我在数据库的第一个版本中有以下模型:
@Table(name = DBConstants.TABLE_CHATS)
public class Chat extends Model {
@Column(name = DBConstants.COLUMN_CHATS_CHAT_ID,unique = true,onUniqueConflict = Column.ConflictAction.REPLACE)
public String chatId;
@Column(name = DBConstants.COLUMN_CHATS_CHAT_MESSAGE)
public String chatMessage;
@Column(name = DBConstants.COLUMN_CHATS_SENDER_NAME)
public String chatSenderName;
@Column(name = DBConstants.COLUMN_JOBS_JOB_ID)
public String chatJobId;
@Column(name = "extra_column")
public String extraColumn;
public Chat(){super();}
public Chat(String chatId, String chatMessage, String chatSenderName, String chatJobId,String extraColumn){
super();
this.chatId = chatId;
this.chatMessage = chatMessage;
this.chatSenderName =chatSenderName;
this.chatJobId = chatJobId;
this.extraColumn = extraColumn;
}
public static List<Chat> getChats(String jobId) {
return new Select()
.from(Chat.class)
.where("jobId=?",jobId)
.execute();
}
}
现在我想用新列更新上面的模型,所以我用新列更新了模型类,如下所示。
<meta-data android:name="GC_DB_VERSION" android:value="4" />
我正在使用Active android for database,所以我已经完成了以下步骤:
1.在清单文件中更新数据库版本号
ALTER TABLE chat ADD COLUMN extra_column TEXT;
2.在assets / migrations中添加4.sql脚本文件
3.在其中添加了更新查询。
Buzz
android.database.sqlite.SQLiteException:表聊天没有列 命名为extra_column(代码1):,同时编译:INSERT INTO 聊天(chat_message,ID,extra_column,chat_sender_name,的jobId,chatId) 价值观(?,?,?,?,?,?) 10-16 06:54:29.712 16791-16791 / com.example.manikanta.navigationdrawerpattern E / SQLiteDatabase:at android.database.sqlite.SQLiteConnection.nativePrepareStatement(母语 方法) 10-16 06:54:29.712 16791-16791 / com.example.manikanta.navigationdrawerpattern E / SQLiteDatabase:at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:882) 10-16 06:54:29.712 16791-16791 / com.example.manikanta.navigationdrawerpattern E / SQLiteDatabase:at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:493) 10-16 06:54:29.712 16791-16791 / com.example.manikanta.navigationdrawerpattern E / SQLiteDatabase:at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588) 10-16 06:54:29.712 16791-16791 / com.example.manikanta.navigationdrawerpattern ....... 10-16 06:54:29.712 16791-16791 / com.example.manikanta.navigationdrawerpattern E / SQLiteLog: (1)表聊天没有名为extra_column的列
有人可以解释如何解决这个问题吗?
答案 0 :(得分:2)
我已经解决了。
问题原因:
在更改清单文件中的版本号
时,不会调用活动android的迁移脚本解决方法:
我已手动设置数据库版本通过Application.class更改,其中包含以下行:
Configuration configuration = new Configuration.Builder(this).setDatabaseVersion(13).create();
ActiveAndroid.initialize(configuration);
我不知道这是否是正确的做法,任何更好的方法都会受到赞赏。