|
| 1 | +import 'package:path/path.dart'; |
| 2 | +import 'package:sqflite/sqflite.dart'; |
| 3 | +import 'package:path_provider/path_provider.dart'; |
| 4 | +import 'package:sqlbrite/sqlbrite.dart'; |
| 5 | +import 'package:sqlite_bloc_rxdart/data/contact_dao.dart'; |
| 6 | +import 'package:sqlite_bloc_rxdart/data/contact_dao_impl.dart'; |
| 7 | +import 'package:sqlite_bloc_rxdart/data/contact_entity.dart'; |
| 8 | +import 'package:sqlite_bloc_rxdart/data/contact_entry.dart'; |
| 9 | + |
| 10 | +const dbName = 'flutter_sqlite_bloc_rxdart.db'; |
| 11 | + |
| 12 | +class AppDatabase { |
| 13 | + static Database _db; |
| 14 | + static Future<Database> get _dbFuture async => _db ??= await _open(); |
| 15 | + |
| 16 | + final ContactDao contactDao; |
| 17 | + |
| 18 | + AppDatabase() |
| 19 | + : contactDao = ContactDaoImpl(_dbFuture.then((db) => BriteDatabase(db))); |
| 20 | + |
| 21 | + static Future<Database> _open() async { |
| 22 | + final directory = await getApplicationDocumentsDirectory(); |
| 23 | + String path = join(directory.path, dbName); |
| 24 | + return await openDatabase( |
| 25 | + path, |
| 26 | + version: 1, |
| 27 | + onCreate: (Database db, int version) async { |
| 28 | + await db.execute(''' |
| 29 | + CREATE TABLE $tableContacts( |
| 30 | + $columnId INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, |
| 31 | + $columnName TEXT NOT NULL, |
| 32 | + $columnPhone TEXT NOT NULL, |
| 33 | + $columnAddress TEXT NOT NULL, |
| 34 | + $columnMale INTEGER NOT NULL DEFAULT 0, |
| 35 | + $columnCreatedAt TEXT NOT NULL, |
| 36 | + $columnUpdatedAt TEXT NOT NULL |
| 37 | + )'''); |
| 38 | + |
| 39 | + final batch = db.batch(); |
| 40 | + for (int i = 0; i < 200; i++) { |
| 41 | + batch.insert( |
| 42 | + tableContacts, |
| 43 | + ContactEntity( |
| 44 | + address: 'Address $i', |
| 45 | + createdAt: DateTime.now(), |
| 46 | + id: null, |
| 47 | + male: i % 2 == 0, |
| 48 | + name: 'Name $i', |
| 49 | + phone: 'Phone $i', |
| 50 | + updatedAt: DateTime.now(), |
| 51 | + ).toJson(), |
| 52 | + ); |
| 53 | + } |
| 54 | + await batch.commit( |
| 55 | + continueOnError: true, |
| 56 | + noResult: true, |
| 57 | + ); |
| 58 | + }, |
| 59 | + ); |
| 60 | + } |
| 61 | +} |
0 commit comments