Android Room 报错:too many SQL variables (code 1 SQLITE_ERROR) 原因及解决方法

报错信息:

bash 复制代码
android.database.sqlite.SQLiteException: 
	too many SQL variables (code 1 SQLITE_ERROR): 
 		while compiling: SELECT * FROM points WHERE id IN (?,?,?,...,?,?,?)

SQLiteException: too many SQL variables 通常是由于一次查询或插入的 SQL 语句中包含的绑定变量超过了 SQLite 的限制。SQLite 默认的最大绑定变量数量是 999。如果您使用的 SQL 包含的绑定参数(如 IN 查询中的参数个数)超过了这个限制,就会导致此错误。

SQLITE_MAX_VARIABLE_NUMBER 是 SQLite 中定义的绑定变量的最大数量限制,它的值可能因版本和具体的编译配置而有所不同。以下是不同版本的默认值和相关说明:

  • SQLite 3.32.0 及以上版本:
    默认值为 32766。
    这是当前支持的最大值,前提是 SQLite 编译时未限制更小的值。
  • SQLite 3.22.0 到 3.31.1:
    默认值为 999。
  • SQLite 3.6.19 到 3.21.0:
    默认值为 999。
  • SQLite 3.6.18 及更早版本:
    默认值为 250, 500 或 999,具体取决于编译时配置。

解决方法:分批查询

kotlin 复制代码
fun queryInBatches(dao: YourDao, ids: List<Long>): List<YourEntity> {
    val batchSize = 900 // 每批最大数量
    val result = mutableListOf<YourEntity>()

	// 将 ids 按照 batchSize 分成若干小批次。
    ids.chunked(batchSize) { chunk ->
        result.addAll(dao.queryByIds(chunk))
    }

    return result
}
相关推荐
TimeFine12 分钟前
Android 通过Dialog实现全屏
android
养生技术人19 分钟前
Oracle OCP认证考试题目详解082系列第49题
运维·数据库·sql·oracle·database·开闭原则·ocp
white-persist29 分钟前
SQL 注入详解:从原理到实战
前端·网络·数据库·sql·安全·web安全·原型模式
用户20187928316732 分钟前
Android Input 的 “快递双车道”:为什么要用 Pair Socket?
android
ajassi20001 小时前
开源 java android app 开发(十八)最新编译器Android Studio 2025.1.3.7
android·java·开源
用户2018792831671 小时前
Java 泛型:快递站老板的 "类型魔法" 故事
android
Knight_AL1 小时前
浅拷贝与深拷贝详解:概念、代码示例与后端应用场景
android·java·开发语言
夜晚中的人海2 小时前
【C++】智能指针介绍
android·java·c++
用户2018792831673 小时前
后台Activity输入分发超时ANR分析(无焦点窗口)
android
用户2018792831673 小时前
Activity配置变化后ViewModel 的 “不死之谜”
android