Room

    [JETPACK개론] ROOM(3)

    [JETPACK개론] ROOM(3)

    ROOM드디어 마지막 포스팅!! 이제 전 글에 이어서 LiveData와 RecyclerView, 그리고 Repository이용해서 불러오는 것까지 구현해보자! 먼저 레이아웃에 리사이클러뷰, item 그리고 어댑터클래스부터 먼저 생성해주자. class CustomAdapter(private val dataSet : List) : RecyclerView.Adapter() { class ViewHolder(view : View) : RecyclerView.ViewHolder(view){ val textView : TextView = view.findViewById(R.id.textView) } override fun onCreateViewHolder(parent: ViewGroup, viewType: Int)..

    [JETPACK개론] ROOM(2)

    이 글은 전에 포스팅했던 ROOM(1)에 이어서 공부한 내용을 정리해보겠다! 저번 코드에 이어서 Multi Table, 테이블을 하나 추가하고, 이를 ViewModel로 분리하여 왜 viewModelScope에서 Disaptchers.IO를 사용하는지까지 알아보자. text_table만 있던 데이터베이스에 word_table이라는 테이블을 추가해보자. @Entity(tableName = "word_table") data class WordEntity ( @PrimaryKey(autoGenerate = true) @ColumnInfo(name = "id") var id : Int, @ColumnInfo(name = "text") var text : String ) 테이블을 만들어 주었으니 Dao에 똑같이 ..

    [JETPACK개론] ROOM(1)

    [JETPACK개론] ROOM(1)

    전에 포스팅했던 글에서 SQLite에 대해서 다뤄보았다. SQLite 게시물 바로가기 -> [JETPACK개론] SQLite(1) 앱을 이용하다보면 네트워크가 끊겼을 때 네트워크 오류입니다. 다시 시도해 주세요 라는 메세지를 본 적이 있다. 하지만 카카오톡 채팅방처럼 네트워크가 연결되어 있지 않은 상황에서도 잘 ssongcode.tistory.com Room은 SQLite를 완벽히 활용하면서 원활한 데이터베이스 엑세스가 가능하도록 하는 업그레이드 버전이라 할 수 있다. 여러 장점이 있지만 반복적이고 오류가 발생하기 쉬운 상용구 코드를 최소화하는 것이 Room의 장점이다. 이러한 이유로 JetPack 라이브러리에 포함된 Room의 사용을 권장하고 있다! Room 구성요소 데이터베이스 - 데이터베이스는 앱..

    [JETPACK개론] SQLite(2)

    [JETPACK개론] SQLite(2)

    전에 포스팅했던 내용에 이어서 SQLite를 다뤄볼 예정이다! 전 글에서는 SQLite에서 테이블을 만들고, insert하고, delete하고, select하는 구문을 작성했으면 이번 글에서는 view를 간단히 만들어보고 이 뷰에서 어떻게 활용할 수 있는지 다뤄볼 것이다! 먼저 위에 EditText에서 작성한 것을 insert버튼을 눌렀을 때 테이블에 들어가고, GetAll 버튼을 눌렀을 때에는 resultArea에 테이블에 있던 값이 나오고, DeleteAll을 했을 때에는 테이블의 전체 값을 삭제하는 것을 확인할 것이다. insert구문 fun insert(str : String) { val db = this.writableDatabase val values = ContentValues().apply..

    [JETPACK개론] SQLite(1)

    앱을 이용하다보면 네트워크가 끊겼을 때 네트워크 오류입니다. 다시 시도해 주세요 라는 메세지를 본 적이 있다. 하지만 카카오톡 채팅방처럼 네트워크가 연결되어 있지 않은 상황에서도 잘 보이고 있는 것을 알 수 있다. 서버에서 불러오는 방식일 수도 있지만 다른 곳에다가 저장을 해두고, 불러오는 방식을 사용할 수 있을 것이다. 우리는 이를 Local DB라고 부르며 SQLite와 Room이 있다. Room은 SQLite를 완벽히 활용하면서 원활한 데이터베이스 엑세스가 가능하도록 하는 업그레이드 버전이라 할 수 있다. 여러 장점이 있지만 반복적이고 오류가 발생하기 쉬운 상용구 코드를 최소화하는 것이 Room의 장점이다. 먼저 Room을 공부하기전 SQLite의 개념을 알고, Room을 공부할 예정이다! 이 글에..