Я хочу реализовать функцию, которая, когда я прокручиваю элемент списка, удаляет этот элемент из базы данных. я использовал dismisible для части салфетки и удаления, но я не знаю, как удалить элемент из базы данных. это мой вспомогательный файл базы данных:
import 'package:path/path.dart';
import 'package:sqflite/sqflite.dart';
import 'package:wodo/models/task.dart';
class DatabaseHelper {
Future<Database> database() async {
return openDatabase(
join(await getDatabasesPath(), 'todo_database.db'),
onCreate: (db, version) {
return db.execute(
"CREATE TABLE tasks(id INTEGER PRIMARY KEY, name TEXT, date TEXT)");
},
version: 1,
);
}
Future<void> insertTask(Task task) async {
Database _db = await database();
await _db.insert('tasks', task.toMap(),
conflictAlgorithm: ConflictAlgorithm.replace);
}
Future<List<Task>> getTasks() async {
Database db = await database();
List<Map<String, dynamic>> taskMap = await db.query('tasks');
return List.generate(taskMap.length, (index) {
return Task(
id: taskMap[index]['id'],
name: taskMap[index]['name'],
date: taskMap[index]['date']);
});
}
}
Чтобы удалить элемент, просто используйте метод удаления. Как описано в документации
db.delete(TABLE_NAME, where: "id = ?", whereArgs: [id]);
Вот что вы можете сделать для фактической стороны базы данных:
Future<int> delete(int id) async {
final db = await database; // replacd with database instance
return await db.delete(
TABLE, // replace with table name
where: "id = ?",
whereArgs: [id], // you need the id
);
}
а затем, чтобы обновить экран, вам нужно сделать что-то вроде этого:
DatabaseProviderLog.db.delete(log.id).then((_){ // call this action
BlocProvider.of<LogBloc>(context).add(
DeleteLog(index), // uses Bloc Provider and an event to update screen
);
}
событие, которое находится в отдельном файле:
import 'package:FilamentLeft/models/profiles.dart';
abstract class ProfileEvent {}
class UpdateProfile extends ProfileEvent {
Profile newProfile;
int profileIndex;
UpdateProfile(int index, Profile profile) {
newProfile = profile;
profileIndex = index;
}
}
class SetProfiles extends ProfileEvent {
List<Profile> profileList;
SetProfiles(List<Profile> profiles) {
profileList = profiles;
}
}
class AddProfile extends ProfileEvent {
Profile newProfile;
AddProfile(Profile profile) {
newProfile = profile;
}
}
class DeleteProfile extends ProfileEvent {
int profileIndex;
DeleteProfile(int index) {
profileIndex = index;
}
}
вам, вероятно, следует немного прочитать SQL/lite и, вероятно, прочитать - developer.android.com/reference/android/database/sqlite/… Избегайте создания команд самостоятельно, если можете (если это не необходимо)