批量写入 → Room 事务

批量写入 → Room 事务

老写法(Java + SQLite)

java 复制代码
// 逐条插入 --- 慢
for (Item item : items) {
    ContentValues values = new ContentValues();
    values.put("name", item.getName());
    values.put("price", item.getPrice());
    db.insert("item", null, values);
}

// 手动事务
db.beginTransaction();
try {
    for (Item item : items) {
        ContentValues values = new ContentValues();
        values.put("name", item.getName());
        values.put("price", item.getPrice());
        db.insert("item", null, values);
    }
    db.setTransactionSuccessful();
} finally {
    db.endTransaction();
}

问题在哪里

不用事务时,每条 insert 都是一次独立的磁盘写入,1000 条数据可能要几秒甚至十几秒。手动开事务样板代码又多又容易漏掉 setTransactionSuccessful / endTransaction。忘写一个数据就不持久。

新写法(Room + Kotlin)

kotlin 复制代码
// 批量插入 --- 单条 @Insert 支持可变参数和 List
@Insert
suspend fun insertAll(items: List<Item>)

// 或直接在 DAO 里定义事务
@Transaction
suspend fun replaceAll(items: List<Item>) {
    deleteAll()
    insertAll(items)
}

// Repository 层用 withTransaction
class ItemRepository(private val db: AppDatabase, private val dao: ItemDao) {

    suspend fun importItems(items: List<Item>) {
        db.withTransaction {
            for (item in items) {
                dao.insert(item)
            }
        }
    }
}

一句话注意

Room 的 @Insert 传 List 时内部已经用事务包装,不必手动再套一层事务。但如果需要在一个事务里执行不同类型的操作(先删后插、多表更新),用 @Transaction 注解或 withTransaction

@Transaction 用在 DAO 的 suspend 方法上时,Room 保证方法体在一个数据库事务里执行。但不能用在返回 Flow 的方法上------Flow 是长时间运行的观察者,事务只在单次数据库操作期间存在。


Java Android 老项目迁移系列,持续更新中。

相关推荐
宋哥转AI1 小时前
MCP 第一天我没写@Tool,先在一个大仓库里划这三层
java·agent·mcp
填满你的记忆1 小时前
MCP协议是什么?为什么它被称为AI时代的“USB接口”?
java·人工智能·agent·mcp
云烟成雨TD1 小时前
Spring AI Alibaba 1.x 系列【72】集成 MCP 客户端
java·人工智能·spring
独隅1 小时前
Visual Studio Code 和 Visual Studio 2026 两大开发工具的核心差异
java·vscode·visual studio
我登哥MVP1 小时前
SpringCloud 核心组件解析:服务注册与发现
java·spring boot·后端·spring·spring cloud·java-ee·maven
ZHECSDN1 小时前
Java模板方法模式:缓存操作重复写?把骨架抽出来
java·模板方法模式
傅科摆 _ py1 小时前
AI Ping 平台使用教程
java·前端·人工智能
杉氧1 小时前
Kotlin 协程深度解析①:内核解密——揭秘 suspend 挂起函数的灵魂
android·kotlin
风味蘑菇干1 小时前
JDBC(数据库连接池&DBUtils)
java·数据库