Подсчитывать записи и возвращать общее количество записей в реальном времени, а затем отображать его в виде текста в виджете. - PullRequest
0 голосов
/ 07 января 2020

Я пытаюсь получить общее количество записей таблицы базы данных sqlite, называемых «персоны». После получения общего количества записей я хочу показать это число в виджете Container внутри виджета Text(). Я пробовал разные способы сделать эту работу, но не все методы, которые я использовал, работают.

Ниже приведен файл db_helper.dart . Функция, которая должна возвращать общее количество записей, определяется как countPeople.

import 'dart:async';
import 'dart:io' as io;
import 'package:path_provider/path_provider.dart';
import 'package:sqflite/sqflite.dart';

/// models

import 'package:path/path.dart';

class DBHelper {
  static Database db_instance;

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

  initDB() async {
    var databasesPath = await getDatabasesPath();
    String path = join(databasesPath, 'development.db');
    var db = await openDatabase(path, version: 1, onCreate: onCreateFunc);
    return db;
  }

  void onCreateFunc(Database db, int version) async {
    // create table
    await db.execute('''CREATE TABLE persons(
      id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, nickname TEXT, country_id INTEGER, role TEXT, created DATETIME, updated DATETIME
    );''');
  }

  /**
   * crud functions
   */

  void countPeople() async {
    var db_connection = await db;
    final count = Sqflite.firstIntValue(
        await db_connection.rawQuery('SELECT COUNT(*) FROM persons'));
    // assert(count == 2);
    print('people count: $count');
  }
  Future<List<Person>> getAllPersons() async {
    final db_connection = await db;
    var response = await db_connection
        .rawQuery("SELECT * FROM persons ORDER BY created DESC");
    // print(response);
    List<Person> list = response.map((c) => Person.fromJson(c)).toList();
    return list;
  }

  // add new person
  void addNewPerson(Person person) async {
    var db_connection = await db;
    String query = """
        INSERT INTO persons(name,nickname,role,created,updated) VALUES('${person.name}','${person.nickname}', '${person.role}','${person.created}', '${person.updated}')
        """;
    await db_connection.transaction((transaction) async {
      // print(query);
      return await transaction.rawInsert(query);
    });
  }

Ниже приведен файл people_count.dart . Здесь я хочу, чтобы общее количество записей отображалось в виджете Text().

import 'package:flutter/material.dart';
import 'package:com.example.simple_app/utils/db_helper.dart';
import 'package:com.example.simple_app/models/person.dart';
import 'package:com.example.simple_app/pages/main_user_registration/create_account.dart';

class MainUserRegistration extends StatefulWidget {
  MainUserRegistration({Key key}) : super(key: key);

  @override
  _MainUserRegistrationState createState() => _MainUserRegistrationState();
}

var dbHelper = DBHelper();

class _MainUserRegistrationState extends State<MainUserRegistration> {
  var result = dbHelper.countPeople();

  @override
  Widget build(BuildContext context) {
    return new Scaffold(
      appBar: new AppBar(
        title: Text('Loans'),
      ),
      body: new Container(
        child: Row(
          children: <Widget>[
            Text('all persons: ${dbHelper.countPeople()}'), // the total number of records should appear here
          ],
        ),
      ),
    );
  }
}

1 Ответ

2 голосов
/ 07 января 2020

Вы, вероятно, должны попытаться использовать setState() для изменения асинхронных c данных на initState, вот как будет выглядеть people_count.dart:

import 'package:flutter/material.dart';
import 'package:com.example.simple_app/utils/db_helper.dart';
import 'package:com.example.simple_app/models/person.dart';
import 'package:com.example.simple_app/pages/main_user_registration/create_account.dart';

class MainUserRegistration extends StatefulWidget {
  MainUserRegistration({Key key}) : super(key: key);

  @override
  _MainUserRegistrationState createState() => _MainUserRegistrationState();
}

var dbHelper = DBHelper();

class _MainUserRegistrationState extends State<MainUserRegistration> {
  int number = -1;

  void countPeople() async {
    int count = await dbHelper.countPeople();
    setState(() => number = count);

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

  @override
  Widget build(BuildContext context) {
    return new Scaffold(
      appBar: new AppBar(
        title: Text('Money Lender'),
      ),
      body: new Container(
        child: Row(
          children: <Widget>[
            Text('all persons: ${number}'), // the total number of records should appear here
          ],
        ),
      ),
    );
  }
}

И функция подсчета людей в db_helper.dart должно возвращать количество людей:

Future<int>countPeople() async {
    var db_connection = await db;
    final count = Sqflite.firstIntValue(
        await db_connection.rawQuery('SELECT COUNT(*) FROM persons'));
    // assert(count == 2);
    print('people count: $count');
    return count;
  }
...