update数据库时出现不存在的列:Unknown column name 'serialVersionUID' in table

查看该表,发现并没有实现实例化接口。
通过下面方法反射出所有的属性,发现确实多了一个$change 和一个serialVersionUID。

public static void showAnnotationWrodOther(){
        Field[] fields = DbApp.class.getFields();
        for (Field field : fields) {
            field.setAccessible(true);
            LogUtil.d("DbAppfield  getFields name = " + field.getName());
        }
        fields = DbApp.class.getDeclaredFields();
        for (Field field : fields) {
            field.setAccessible(true);
            LogUtil.d("DbAppfield  getDeclaredFields name = " + field.getName());
        }
}

change.png

通过查阅资料,AndroidStudio开启InstantRun时会出现这种情况。过程存在序列化操作。所以关闭InstantRun。
File>Settings>Instant Run 选项全部关闭。
猜测热修复也可能会有这种情况?(不确定)

但是一般情况下,多出的这两个属性不应该会影响插入数据库。但是我们底层封装数据库的时候并不严谨。
是通过反射获取的所有不为空的属性作为表列。所以也会把这个属性认为是存在的列。

解决办法:
1.关闭Instant Run
2.修改框架,根据是否有DatabaseField注解来获取对应的列。field.isAnnotationPresent(DatabaseField.class);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值