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,23 @@
import 'package:game_tracker/data/database.dart';
import 'package:drift/drift.dart';
extension MatchDao on AppDatabase {}
extension MatchDao on AppDatabase {
Future<List<MatchTableData>> getAllMatches() async {
return await select(matchTable).get();
}
Future<MatchTableData> getMatchById(String id) async {
return await (select(
matchTable,
)..where((m) => m.id.equals(id))).getSingle();
}
Future<void> addMatch(String matchId, int gameId, String groupId, DateTime createdAt) async {
await into(
matchTable,
).insert(MatchTableCompanion.insert(id: matchId, gameId: gameId, groupId: groupId, createdAt: createdAt));
}
Future<void> deleteMatchById(String id) async {
await (delete(matchTable)..where((m) => m.id.equals(id))).go();
}
}