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:
-
Cree la tabla necesaria (users.sql)
CREATE TABLE users( firstname TEXT NOT NULL, lastname TEXT NOT NULL, dob TEXT NOT NULL );
-
Crea la base de datos sqlite
sqlite3 database.db < users.sql
-
Inserte los datos csv
sqlite3 database.db .mode csv .import data.csv users
-
Coloque database.db en sus activos y agréguelo en pubspec.yaml.
flutter: # ... assets: - assets/database.db
-
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); }
-
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;
-
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)