为什么使用 sqflite 删除行在 flutter 中不起作用?

Why Deleting Row using sqflite dont work in flutter?

提问人:Talat Saleh 提问时间:11/13/2023 最后编辑:Talat Saleh 更新时间:11/13/2023 访问量:29

问:

我在删除应用程序中的行时遇到了问题,它删除没有错误,但是在获取数据时,它仍然在那里,就像它从未删除过一样 我正在使用 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();

重新加载时,文件中删除了图像错误

那么,为什么会这样呢?

Flutter 飞镖 路径 SQFLITE 移动开发

评论

0赞 Wh1t3rabbit 11/13/2023
“这是从数据库获取数据的函数”,但随后您再次粘贴了 getDatabase 函数。
0赞 Talat Saleh 11/13/2023
哦,我的错误,我编辑了它

答: 暂无答案