[英]Room Database Migration - Bitmap
我正在使用 Room 數據庫,我更新了我的 model。 這就是我進行遷移以便不刪除現有數據的原因。 我正在嘗試在遷移時在 SQL 代碼中添加 bitmap,但出現錯誤。 如何使用 SQL 代碼添加 bitmap?
Model:
@Entity(tableName = "person_table")
data class PersonModel(
@PrimaryKey(autoGenerate = true)
val id: Int,
val name: String,
val surname: String,
val profilePicture: Bitmap
)
數據庫:
@Database(entities = [PersonModel::class], version = 2, exportSchema = true)
@TypeConverters(Converter::class)
abstract class PersonDatabase : RoomDatabase() {
abstract fun personDao(): PersonDao
companion object {
@Volatile
private var INSTANCE: PersonDatabase? = null
fun getDatabase(context: Context): PersonDatabase {
return INSTANCE ?: synchronized(this) {
val instance = Room.databaseBuilder(
context.applicationContext,
PersonDatabase::class.java,
"PersonDatabase"
).addMigrations(MIGRATION_1_2)
.build()
INSTANCE = instance
instance
}
}
val MIGRATION_1_2 = object : Migration(1, 2) {
override fun migrate(database: SupportSQLiteDatabase) {
database.execSQL(
"ALTER TABLE person_table ADD COLUMN profilePicture BITMAP"
)
}
}
}
}
轉換器:
class Converter {
@TypeConverter
fun fromBitmap(bitmap: Bitmap): ByteArray {
val outputStream = ByteArrayOutputStream()
bitmap.compress(Bitmap.CompressFormat.PNG, 100, outputStream)
return outputStream.toByteArray()
}
@TypeConverter
fun toBitmap(byteArray: ByteArray): Bitmap {
return BitmapFactory.decodeByteArray(byteArray, 0, byteArray.size)
}
}
Room 不支持 bitmap 但支持 BLOB 類型所以你可以這樣使用
@ColumnInfo(typeAffinity = ColumnInfo.BLOB)
val profilePicture: ByteArray? = null
並添加擴展以將 bitmap 轉換為字節數組
fun Bitmap.toByteArray(quality: Int = 50): ByteArray {
val stream = ByteArrayOutputStream()
compress(Bitmap.CompressFormat.JPEG, quality, stream)
return stream.toByteArray()
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.