plzy의 개발 블로그

[Android] Room 어떻게 써야할까 ? 본문

Android

[Android] Room 어떻게 써야할까 ?

plzyhappy 2021. 2. 19. 20:51

안녕하세요,오늘 안드로이드 에 쓰이는 데이터베이스 중, Room 에 대해 설명해 드리려고 합니다.

Room 이란 Android 에서 권장하는 NoSQl문으로 Sqllite 대신 Room 쓰는 것을 권장하고 있습니다

Room 에 대해 간략히 설명해드리면

User 데이터베이스 테이블을 담고 있습니다.
UserDao 쿼리를 쓸 수 있는 곳입니다.
AppDatabase 데이터베이스 객체를 담고 있는 곳입니다.

Room 을 사용하려면 먼저 build.gradle 에 추가할 것이 몇 가지 있는데요

dependencies {
  def room_version = "2.2.6"

  implementation "androidx.room:room-runtime:$room_version"
  kapt "androidx.room:room-compiler:$room_version"

  // optional - Kotlin Extensions and Coroutines support for Room
  implementation "androidx.room:room-ktx:$room_version"

  // optional - Test helpers
  testImplementation "androidx.room:room-testing:$room_version"
}

를 build.gradle에 복붙 하시면 됩니다.


Entity
테이블 이름을 지정할수 있습니다. 기본 값은 class 이름입니다.
PrimaryKey
기본키를 지정할수 있습니다. 이때 autoGenerate=true를 해주시면 자동으로 key 값을 생성해 줍니다.

@Entity
    data class User(
       @PrimaryKey val uid: Int,
       val firstName: String?,
       val lastName: String?
    )
}

Qury
Sql Qury문과 똑같이 쿼리문을 작성할수 있습니다.

@Dao  
interface UserDao {  
@Query("SELECT \* FROM user")  
fun getAll(): List

@Query("SELECT * FROM user WHERE uid IN (:userIds)")
fun loadAllByIds(userIds: IntArray): List<User>


@Insert
fun insertAll(vararg users: User)

@Delete
fun delete(user: User)

}

AppDatabase

@Database(entities = {User::class}, version = 1)  
abstract class AppDatabase : RoomDatabase() {  
abstract fun userDao(): UserDao  
}

RoomDB 쓸 액티비티에 이코드를 넣는다. RoomDB를 많이 쓴다면, 메소드 시키는것도 좋은 방법이다.

val db = Room.databaseBuilder(  
applicationContext,  
AppDatabase::class.java, "UsER"  
).build()