提问人:Talat Saleh 提问时间:11/13/2023 最后编辑:Talat Saleh 更新时间:11/13/2023 访问量:29
为什么使用 sqflite 删除行在 flutter 中不起作用?
Why Deleting Row using sqflite dont work in flutter?
问:
我在删除应用程序中的行时遇到了问题,它删除没有错误,但是在获取数据时,它仍然在那里,就像它从未删除过一样 我正在使用 sqflite 包 这是获取数据库的函数:
Future<Database> _getDatabase() async {
final dbPath = await sql.getDatabasesPath();
print('get database path');
final db = await sql.openDatabase(
path.join(dbPath, 'placesFav.db'),
onCreate: (db, version) {
print('creating table');
return db.execute(
'CREATE TABLE $_tableName(id TEXT PRIMARY KEY, title TEXT, image TEXT, lat REAL, lng REAL, address TEXT)');
},
version: 1,
);
return db;
}
这是从数据库获取数据的函数:
Future<void> getPlaces() async {
final db = await _getDatabase();
final dataOfDb = await db.query(
_tableName,
);
state = dataOfDb
.map(
(row) => FavoritePlace(
id: row['id'] as String,
title: row['title'] as String,
image: File(row['image'] as String),
favLocation: FavoriteLocation(
latitude: row['lat'] as double,
longitude: row['lng'] as double,
address: row['address'] as String,
),
),
)
.toList();
await db.close();
}
这是删除行函数:
Future<void> removePlace(FavoritePlace favPlace) async {
state = state.where((place) => place.id != favPlace.id).toList();
final db = await _getDatabase();
final data =
await db.delete(_tableName, where: 'id = ?', whereArgs: [favPlace.id]);
print(data);
await favPlace.image.delete();
await db.close();
}
}
这是添加位置函数:
void addPlace(FavoritePlace favPlace) async {
final appDir = await app_path.getApplicationDocumentsDirectory();
final imageName = path.basename(favPlace.image.path);
final cImage =
await favPlace.image.copy('${appDir.path}/${favPlace.id[3]}$imageName');
state = [...state, favPlace];
final db = await _getDatabase();
await db.insert(_tableName, {
'id': favPlace.id,
'title': favPlace.title,
'image': cImage.path,
'lat': favPlace.favLocation.latitude,
'lng': favPlace.favLocation.longitude,
'address': favPlace.favLocation.address,
});
await db.close();
print('db closed');
}
这是我使用它的地方:
class _HomeScreenStateConsumer extends ConsumerState<HomeScreen> {
List<FavoritePlace> favList = [];
late Future<void> _loadPlaces;
AppBar _appBar(BuildContext context) {
return AppBar(
actions: [
IconButton(
onPressed: () async {
final favPlace = await Navigator.of(context)
.push<FavoritePlace>(MaterialPageRoute(builder: (ctx) {
return const AddNewPlace();
}));
if (favPlace == null) {
return;
}
},
icon: const Icon(Icons.add),
),
],
title: const Text('Favorite places'),
);
}
@override
void initState() {
_loadPlaces = ref.read(favoritePlaceProvider.notifier).getPlaces();
super.initState();
}
Future<void> _getRefresh() async {
await ref.read(favoritePlaceProvider.notifier).getPlaces();
}
@override
Widget build(BuildContext context) {
final height = MediaQuery.of(context).size.height -
_appBar(context).preferredSize.height -
MediaQuery.of(context).padding.top;
favList = ref.watch(favoritePlaceProvider);
print(favList.length);
return Scaffold(
appBar: _appBar(context),
body: RefreshIndicator(
onRefresh: _getRefresh,
triggerMode: RefreshIndicatorTriggerMode.onEdge,
child: FutureBuilder(
future: _loadPlaces,
builder: (context, snapshot) => snapshot.connectionState ==
ConnectionState.waiting
? const Center(
child: CircularProgressIndicator(),
)
: favList.isEmpty
? SingleChildScrollView(
physics: const AlwaysScrollableScrollPhysics(),
child: Container(
height: height,
alignment: Alignment.center,
child: Text(
'There is no places to see',
style: Theme.of(context)
.textTheme
.titleMedium!
.copyWith(
color: Colors.white,
),
),
),
)
: Padding(
padding: EdgeInsets.all(8),
child: ListView.builder(
itemCount: favList.length,
itemBuilder: (ctx, index) {
print(favList[index].title);
return Dismissible(
key: ValueKey(favList[index].id),
direction: DismissDirection.horizontal,
onDismissed: (_) async {
setState(() {
ref
.read(favoritePlaceProvider.notifier)
.removePlace(favList[index]);
});
},
child:
FavoriteItem(favPlace: favList[index]));
},
),
),
),
),
);
}
}
我本来以为那行被删除了,但它在应用程序中确实删除了,但是当再次获取时,它再次出现,因为:
await favPlace.image.delete();
重新加载时,文件中删除了图像错误
那么,为什么会这样呢?
答: 暂无答案
评论