批量写入 → 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 老项目迁移系列,持续更新中。

相关推荐
Flittly3 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了3 小时前
Java 生成二维码解决方案
java·后端
石山岭3 小时前
自己动手写了一个 Android 虚拟定位 App:GPSSimulate 技术实
android·前端
杉氧5 小时前
副作用 (Side Effects) 全攻略:如何像大师一样掌控 Composable 的生命周期?
android·架构·android jetpack
人活一口气8 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP9 小时前
Vibe Coding -- 完整项目案例实操
java
唐青枫9 小时前
别再把 inline 当性能开关:Kotlin 内联、noinline、crossinline 与 reified 实战详解
kotlin
荣码9 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing9 小时前
Google第三方授权登录
java·后端·程序员
明月光8189 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java