Saltar al contenido

Sqlite en flutter, como funcionan los activos de la base de datos

Solución:

En primer lugar, deberá construir una base de datos sqlite a partir de su csv. Esto se puede hacer de la siguiente manera:

  1. Cree la tabla necesaria (users.sql)

    CREATE TABLE users(
       firstname TEXT NOT NULL,
       lastname TEXT NOT NULL,
       dob TEXT NOT NULL
    );
    
  2. Crea la base de datos sqlite

    sqlite3 database.db < users.sql
    
  3. Inserte los datos csv

    sqlite3 database.db
    .mode csv
    .import data.csv users
    
  4. Coloque database.db en sus activos y agréguelo en pubspec.yaml.

    flutter:
      # ...
      assets:
        - assets/database.db
    
  5. En su aplicación, deberá copiar el archivo de activos en “documentos”. Esto es un poco complicado.

    // Construct a file path to copy database to
    Directory documentsDirectory = await getApplicationDocumentsDirectory();
    String path = join(documentsDirectory.path, "asset_database.db");
    
    // Only copy if the database doesn't exist
    if (FileSystemEntity.typeSync(path) == FileSystemEntityType.notFound){
      // Load database from asset and copy
      ByteData data = await rootBundle.load(join('assets', 'database.db'));
      List<int> bytes = data.buffer.asUint8List(data.offsetInBytes, data.lengthInBytes);
    
      // Save copied asset to documents
      await new File(path).writeAsBytes(bytes);
    }
    
  6. Por último, puede acceder a la base de datos así.

    Directory appDocDir = await getApplicationDocumentsDirectory();
    String databasePath = join(appDocDir.path, 'asset_database.db');
    this.db = await openDatabase(databasePath);
    initialized = true;
    
  7. Consulta de ejemplo (this._initialize () es el paso 6)

    Future<List<Page>> search(String word, int parentId) async {
        if (!initialized) await this._initialize();
        String query = '''
          SELECT * FROM users
          LIMIT 25''';
        return await this.db.rawQuery(query);
    }
    
¡Haz clic para puntuar esta entrada!
(Votos: 0 Promedio: 0)



Utiliza Nuestro Buscador

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *