Асинхронное ожидание базы данных занимает много времени - PullRequest
0 голосов
/ 15 октября 2019

В моем случае мне нужно загрузить некоторые данные из базы данных в начале приложения. Но я не могу загрузить данные, поэтому я проверил, что не так с моим кодом, и обнаружил, что это занимает некоторое время в await database, и код пропускает эту функцию и выполняет другие операции. В результате я получаю данные позже после создания пользовательского интерфейса, поэтому не могу показать данные. Есть ли способ это исправить? Это мой код и результат -

dbhelper.dart

    static Database db_instance;

      Future<Database> get db async{
        if(db_instance == null)
        db_instance = await initDB();
        return db_instance;
      }

      initDB() async{
        var dbDir = await getDatabasesPath();
        var dbPath = join(dbDir, "test.db");
        ByteData data = await rootBundle.load(join("assets","test.db"));
        List<int> bytes = data.buffer.asUint8List(data.offsetInBytes, data.lengthInBytes);
        await File(dbPath).writeAsBytes(bytes);

        var db = await openDatabase(dbPath);
        return db;
      }

    getTest() async{
     print("Test1");
     var db_connection = await db;
     print("Test2");
     List<Map> list = await db_connection.rawQuery('SELECT * FROM $TABLE_NAME Where id= 1');
     print("Test3");
     for(int i=0;i<list.length;i++){
       print("Test4");
       id = list[i]['id'];
       name = list[i]['name'];
       phone = list[i]['phone'];
      }
     print("Test5"+name);
   }

main.dart

getContactsFromDB()async{
  var dbHelper = DBHelper();
  dbHelper.getTest();
  print("Test6"+phone);
}

@override
  void initState()  {
    getContactsFromDB();
    super.initState();
  }

Результат

I/flutter (13203): Test1
I/flutter (13203): Test6 // skip Test2,3,4,5 and jump to another operation and data not collected
I/flutter (13203): Test2
I/flutter (13203): Test3
I/flutter (13203): Test4
I/flutter (13203): Test5 Zin

1 Ответ

1 голос
/ 15 октября 2019

Просто используйте FutureBuilder. Примерно так:

Widget projectWidget() {
   return FutureBuilder(
     future: getContactsFromDB(),
     builder: (context, snapshot) {
       if (snapshot.connectionState == ConnectionState.done) {
           return Container();
       } else {
           return CircularProgressIndicator();
       }
    }
  ) 
}
...