brick_sqlite 3.1.1+1 brick_sqlite: ^3.1.1+1 copied to clipboard
SQLite connector for Brick, a data persistence library for Flutter
import 'package:brick_core/core.dart';
import 'package:brick_sqlite/brick_sqlite.dart';
// Use sqflite when building for Flutter
// import 'package:sqflite/sqflite.dart' show databaseFactory;
import 'package:sqflite_common_ffi/sqflite_ffi.dart' show databaseFactory;
/// This class and code is always generated.
/// It is included here as an illustration.
/// Sqlite adapters are generated by domains that utilize the brick_sqlite_generators package,
/// such as brick_offline_first_with_rest_build
class UserAdapter extends SqliteAdapter<User> {
final tableName = 'User';
final fieldsToSqliteColumns = {
'primaryKey': const RuntimeSqliteColumnDefinition(
association: false,
columnName: '_brick_id',
iterable: false,
type: int,
),
'name': const RuntimeSqliteColumnDefinition(
association: false,
columnName: 'name',
iterable: false,
type: String,
),
};
primaryKeyByUniqueColumns(instance, executor) async => instance.primaryKey;
fromSqlite(data, {required provider, repository}) async {
return User(
name: data['name'],
);
}
toSqlite(instance, {required provider, repository}) async {
return {
'name': instance.name,
};
}
}
/// This value is always generated.
/// It is included here as an illustration.
/// Import it from `lib/brick/brick.g.dart` in your application.
final dictionary = SqliteModelDictionary({
User: UserAdapter(),
});
/// A model is unique to the end implementation (e.g. a Flutter app)
class User extends SqliteModel {
final String? name;
User({
this.name,
});
}
class MyRepository extends SingleProviderRepository<SqliteModel> {
MyRepository()
: super(
SqliteProvider(
'myApp.sqlite',
databaseFactory: databaseFactory,
modelDictionary: dictionary,
),
);
}
void main() async {
final repository = MyRepository();
final users = await repository.get<User>();
print(users);
}