我一直在尝试使用 FTS 表的新 Android 的 Room 2.1 功能来启用搜索功能。
实体:
@Entity
class ChatMessageEntity(
@PrimaryKey
var messageId: String,
var messageUser: String,
var messageText: String,
)
FTS 实体:
@Fts4(contentEntity = ChatMessageEntity::class)
@Entity
class ChatMessageFts(
var messageText: String //only want messageText searchable
)
数据库:
@Database(entities = [ChatMessageEntity::class, ChatMessageFts::class], version = 1)
abstract class ChatMessageDatabase : RoomDatabase() {
abstract fun chatMessageDatabase(): ChatMessageDao
companion object {
fun create(context: Context) = Room.databaseBuilder(context, ChatMessageDatabase::class.java, DB_NAME).build()
}
}
道:
@Query("INSERT INTO ChatMessageFts(ChatMessageFts) VALUES('rebuild')") //works
suspend fun ftsRebuild()
@Query("INSERT INTO ChatMessageFts(docid, messageText) VALUES(:id, :text)") //compiles but doesn't work
suspend fun saveFtsMessage(id: Long, text: String)
当我还在原始表中添加行时,我希望在 FTS 中添加每一行(ChatMessageEntity - 未显示)。从头开始重建 FTS 表时,它工作得很好(ftsRebuild()
上图)。
但是,我希望单独添加每个输入。我已经尝试了很多东西(例如saveFtsMessage()
上面显示的) - 添加没有 docId,尝试使用 rowId,...我什至尝试添加一个新对象ChatMessageEntity
作为ChatMessageFts
输入,但由于错误我没有设法编译它。
任何关于如何在 FTS 表中添加个人输入的建议都非常受欢迎!