Flutter iOS Данные базы данных приложения sqflite потеряны после обновления приложения - PullRequest
0 голосов
/ 10 июля 2020

У нас есть сборка приложения полностью на флаттере. Когда мы отправляем обновления приложений в магазин Google, данные базы данных sqflite не теряются при обновлении apk на устройстве Android. Но в iOS устройстве после обновления приложения пользователем до новой версии все данные базы данных потеряны.

flutter v1.17.5

Пакет, используемый для сохранения данных:

sqflite: ^ 1.3 .1 path_provider: ^ 1.6.11

Не могли бы вы помочь решить эту проблему. Данные пользователя нельзя удалять после обновления приложения до новой версии. Возможно, мне нужно использовать другой тип сохранения данных или как я могу это решить.

Вот части, где я инициализирую базу данных в классе DatabaseHelper:

  class DatabaseHelper {
  static DatabaseHelper _databaseHelper; // Singletone DatabaseHelper
  static Database _database; // Singletone Database

  String wifiSystemTable = 'wifi_system_table';
  String colId = 'id';
  String colDataType = 'data_type';
  String colLocationName = 'location_name';
  String colBackground = 'background';
  String colLocationId = 'location_id';
  String colDeviceType = 'device_type';
  String colIp = 'ip';
  String colName1 = 'name1';
  String colName2 = 'name2';
  String colName3 = 'name3';
  String colRemotePort = 'remote_port';

  DatabaseHelper._createInstance(); // Named constractor to create instance of Database Helper

  factory DatabaseHelper() {
    if (_databaseHelper == null) {
      _databaseHelper = DatabaseHelper
          ._createInstance(); //This is execute only once, singletone object
    }
    return _databaseHelper;
  }

  Future<Database> get database async {
    if (_database == null) {
      _database = await initializeDatabase();
    }
    return _database;
  }

  Future<Database> initializeDatabase() async {
    //Get the directory path for both Android and IOS to store Database
    Directory directory = await getApplicationDocumentsDirectory();
    String path = p.join(directory.toString(), 'wifi.db');

    //Open/create the database at the given path
    var wifiSystemDatabase =
        await openDatabase(path, version: 1, onCreate: _createDb);
    return wifiSystemDatabase;
  }

  void _createDb(Database db, int newVersion) async {
    await db.execute(
        'CREATE TABLE $wifiSystemTable($colId INTEGER PRIMARY KEY, $colDataType INTEGER, $colLocationName TEXT, $colBackground TEXT, $colLocationId INTEGER, $colDeviceType INTEGER, $colIp TEXT, $colName1 TEXT, $colName2 TEXT, $colName3 TEXT, $colRemotePort TEXT)');
  }

Большое спасибо

1 Ответ

0 голосов
/ 11 июля 2020

Я думаю, ваш путь к БД меняется. Попробуйте это.

  Future<Database> initializeDatabase() async {
    //Get the directory path for both Android and IOS to store Database
    String databasesPath = await getDatabasesPath();
    String path = p.join(databasesPath, 'wifi.db');
    //Open/create the database at the given path
    var wifiSystemDatabase = await openDatabase(path, version: 1, onCreate: _createDb);
    return wifiSystemDatabase;
  }

Надеюсь, это поможет :)

...