[kotlin] 룸 데이터베이스의 버전 관리 방법
안드로이드 앱을 개발하다 보면 데이터베이스 스키마가 변경될 때가 있습니다. 룸(Room) 데이터베이스를 사용할 때는 스키마 버전 관리가 중요한데, 이를 위해 몇 가지 방법이 있습니다.
데이터베이스 버전 업데이트
룸 데이터베이스의 버전을 업데이트하는 방법은 크게 세 가지가 있습니다.
- 버전 번호 증가: 데이터베이스의 스키마가 변경될 때마다
RoomDatabase
클래스의entities
배열을 수정하고,@Database
어노테이션의version
속성을 증가시킵니다.
예시:
@Database(entities = [User::class], version = 2)
abstract class MyAppDatabase : RoomDatabase() {
// ...
}
- 마이그레이션 정의: 기존 데이터베이스 스키마를 유지하면서 새로운 스키마로 전환할 수 있는 마이그레이션 함수를 정의합니다.
예시:
val MIGRATION_1_2 = object : Migration(1, 2) {
override fun migrate(database: SupportSQLiteDatabase) {
// 마이그레이션 로직 작성
}
}
@Database(entities = [User::class], version = 2)
abstract class MyAppDatabase : RoomDatabase() {
// ...
}
- 파일에 스키마 버전 저장: 데이터베이스 파일에 스키마 버전을 별도로 저장하고, 이를 사용하여 스키마 변화를 관리합니다.
정리
룸 데이터베이스를 사용할 때는 높은 수준의 버전 관리가 필요합니다. 새로운 버전에서는 이전 버전과의 호환성을 유지하면서 데이터베이스 스키마가 변경될 수 있도록 적절한 버전 관리 전략을 선택해야 합니다.
더 많은 정보를 원하시면 공식 룸 문서를 참고하시기 바랍니다.
위 포스트에서는 룸 데이터베이스의 버전 관리 방법에 대해 알아보았습니다. 더 자세한 내용은 룸 데이터베이스 공식 문서를 참고하시기 바랍니다.