设置sqflite数据库表时缺少列

时间:2019-07-05 10:22:49

标签: android flutter dart sqflite

我目前正在使用flutter框架开发一个android应用程序。 为了设置数据库,我正在使用sqflite插件。

设置数据库的工作方式如下:

  Future<Database> getDbModelDevice() async {
    return openDatabase(join(await getDatabasesPath(), dbNameDevice),
        onCreate: (db, version) {
      return db.execute("""
      CREATE TABLE $tableNameDevice (
        id INTEGER PRIMARY KEY, 
        name TEXT NOT NULL, 
        ip TEXT NOT NULL
        )""");
    },
    version: 1,
    );
  }

这可以按预期工作,并使用表创建数据库。 我对这个话题还很陌生,所以我不知道您是否能以某种方式查看所创建表的结构。我尝试通过在其中插入设备来测试新表:

Future<void> insertDevice(Device device) async {
  db.insert(
    tableNameDevice, 
    device.toMap(),
    conflictAlgorithm: ConflictAlgorithm.replace,
  );
}

Map<String, dynamic> toMap() {
  return {
    'id': id,
    'name': name,
    'ip': ip,
  };
}

调用函数 insertDevice 时,出现以下错误消息:

[ERROR:flutter/lib/ui/ui_dart_state.cc(148)] Unhandled Exception: DatabaseException(table deviceTable has no column named ip (code 1): , while compiling: INSERT OR REPLACE  INTO deviceTable (id, name, ip) VALUES (?, ?, ?)) sql 'INSERT OR REPLACE  INTO deviceTable (id, name, ip) VALUES (?, ?, ?)' args [0, testInsertion, 0.0.0.0]}

其他列似乎起作用,因为在注释 toMap() 中的参数 ip 时,插入起作用了strong>函数可正确插入设备。

我在这里想念什么?任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:0)

@TimBiegeleisen的评论帮助我解决了这个问题。 我正在查看定义的用于删除表的函数,结果发现我删除了错误的表。

自从我修复了问题,现在它可以按预期运行。

感谢您的回答!