美文网首页
更新数据库时出现不存在的列:Unknown column nam

更新数据库时出现不存在的列:Unknown column nam

作者: BrainZou | 来源:发表于2018-08-25 15:01 被阅读13次

    查看该表,发现并没有实现实例化接口。
    通过下面方法反射出所有的属性,发现确实多了一个$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);

    相关文章

      网友评论

          本文标题:更新数据库时出现不存在的列:Unknown column nam

          本文链接:https://www.haomeiwen.com/subject/bdkgiftx.html