implemented dao's for every table

This commit is contained in:
2025-06-28 14:42:49 +02:00
parent bd28912b97
commit 11b7b37b4e
7 changed files with 153 additions and 12 deletions

View File

@@ -1,4 +1,30 @@
import 'package:game_tracker/data/database.dart';
import 'package:drift/drift.dart';
extension GameDao on AppDatabase {}
extension GameDao on AppDatabase {
Future<List<GameTableData>> getAllGames() async {
return await select(gameTable).get();
}
Future<GameTableData> getGameById(int id) async {
return await (select(
gameTable,
)..where((ga) => ga.id.equals(id))).getSingle();
}
Future<void> addGame(int id, String name) async {
await into(
gameTable,
).insert(GameTableCompanion.insert(name: name));
}
Future<void> deleteGameById(int id) async {
await (delete(gameTable)..where((ga) => ga.id.equals(id))).go();
}
Future<void> updateGameName(int id, String newName) async {
await (update(gameTable)..where((ga) => ga.id.equals(id))).write(
GameTableCompanion(name: Value(newName)),
);
}
}