0

0

如何在不重启应用的情况下实时更新 RecyclerView 中的数据库数据

心靈之曲

心靈之曲

发布时间:2026-01-05 13:51:30

|

585人浏览过

|

来源于php中文网

原创

如何在不重启应用的情况下实时更新 RecyclerView 中的数据库数据

当用户通过弹窗向 sqlite 数据库添加新食物项后,recyclerview 未能即时刷新显示新增数据,需手动通知适配器数据变更并插入新项。

在 Android 开发中,RecyclerView 的 UI 更新不会自动感知底层数据(如 ArrayList 或数据库)的变化。即使你已成功将新记录插入 SQLite 数据库(通过 myDB.addFood(...)),若未同步更新适配器持有的数据集合并触发刷新机制,界面上将始终维持旧状态——直到应用重启或手动调用全局刷新(如 notifyDataSetChanged()),但这会牺牲性能与用户体验。

✅ 正确做法:增量更新 + 精准通知

你需要在弹窗提交逻辑中,同步完成三步操作

  1. 写入数据库(已实现);
  2. 更新本地数据源(ArrayList)
  3. 通知 RecyclerView 适配器新增了一条数据

修改 PopUP() 方法中的点击监听逻辑如下:

新视窗CMS企业管理程序 5.1
新视窗CMS企业管理程序 5.1

新视窗企业管理系统是一款小巧、实用、利于后续开发的ASP程序。适合大中小型企业的网站建设。1、新闻管理 2、产品管理 3、订单管理 4、广告管理 5、下载管理 6、留言管理 8、单页栏目(如企业简介,资质荣誉)9、人才招聘等等。 新视窗企业管理系统 5.1 更新日志:1、修改产品列表的图片自动缩略,防止图片变形.2、修改后台添加产品分类时,排序ID不写入数据库的错误.3、修改首页企业简介的链接地址

下载
btnAddFood.setOnClickListener(v -> {
    String foodName = edtFoodName.getText().toString().trim();
    String foodPrice = edtFoodPrice.getText().toString().trim();

    if (foodName.isEmpty() || foodPrice.isEmpty()) {
        Toast.makeText(SecondScreen.this, "请输入完整信息", Toast.LENGTH_SHORT).show();
        return;
    }

    // ✅ 1. 插入数据库
    MyDataBaseHelper myDB = new MyDataBaseHelper(SecondScreen.this);
    myDB.addFood(foodName, foodPrice);

    // ✅ 2. 同步更新内存中的数据列表(关键!)
    foodName.add(foodName);      // 注意:此处变量名应为 foodName(List) vs foodName(String),建议重命名避免混淆
    foodPrice.add(foodPrice);    // 同上,请确保使用正确的 List 变量名(如 foodNames、foodPrices)

    // ✅ 3. 通知适配器在末尾插入一项(推荐方式,高效且带动画)
    customAdapater.notifyItemInserted(foodName.size() - 1);

    // ✅ 可选:关闭弹窗
    myDialog.dismiss();
});
⚠️ 重要命名建议:当前代码中 foodName 既是 ArrayList 又被用作局部 String 变量名,极易引发编译错误或逻辑混乱。请统一规范命名,例如:List foodNames(存储名称)List foodPrices(存储价格)局部变量用 String name = ..., String price = ...

? 补充说明:为何 notifyDataSetChanged() 不推荐?

虽然调用 customAdapater.notifyDataSetChanged() 也能强制刷新整个列表,但它会忽略所有 ViewHolder 复用与动画效果,导致闪烁、卡顿,且无法体现“新增”语义。而 notifyItemInserted(int position) 是更轻量、语义明确、支持默认插入动画的标准实践。

? 进阶提示(可选优化)

  • 若后续支持删除/修改,对应使用 notifyItemRemoved() / notifyItemChanged();
  • 考虑使用 ListAdapter + DiffUtil 实现全自动智能差分更新(尤其适合频繁变更场景);
  • 数据库写入后,可结合 LiveData 或 Room 的 @Query 观察式查询,实现真正的响应式 UI(但本例中因使用原生 SQLite,手动同步仍是合理选择)。

只要确保「数据库写入 → 内存列表更新 → 适配器通知」三步严格串联执行,RecyclerView 即可零延迟呈现最新数据,彻底告别重启应用的临时方案。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

529

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

50

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

193

2025.08.29

CSS position定位有几种方式
CSS position定位有几种方式

有4种,分别是静态定位、相对定位、绝对定位和固定定位。更多关于CSS position定位有几种方式的内容,可以访问下面的文章。

81

2023.11.23

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

340

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2072

2023.08.14

Golang 分布式缓存与高可用架构
Golang 分布式缓存与高可用架构

本专题系统讲解 Golang 在分布式缓存与高可用系统中的应用,涵盖缓存设计原理、Redis/Etcd集成、数据一致性与过期策略、分布式锁、缓存穿透/雪崩/击穿解决方案,以及高可用架构设计。通过实战案例,帮助开发者掌握 如何使用 Go 构建稳定、高性能的分布式缓存系统,提升大型系统的响应速度与可靠性。

53

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 11.1万人学习

Java 教程
Java 教程

共578课时 | 43.7万人学习

Uniapp从零开始实现新闻资讯应用
Uniapp从零开始实现新闻资讯应用

共64课时 | 6.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号