• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

umangburman/MVVM-Room-Kotlin-Example: Android Kotlin MVVM Room Example

原作者: [db:作者] 来自: 网络 收藏 邀请

开源软件名称(OpenSource Name):

umangburman/MVVM-Room-Kotlin-Example

开源软件地址(OpenSource Url):

https://github.com/umangburman/MVVM-Room-Kotlin-Example

开源编程语言(OpenSource Language):

Kotlin 100.0%

开源软件介绍(OpenSource Introduction):

Android’s Room in Kotlin ft. MVVM Architecture and Coroutines

If you’re looking for an explanation on Room implementation on Android using Kotlin and one of it’s Coroutine feature with MVVM architecture, then this one is for you.

Let’s see what I have in store for you.

  1. What is Room, Kotlin, MVVM, Coroutines?
  2. Advantages of Room over SQLite?
  3. Important Annotation in Room.
  4. Step-by-Step Simple Insert and Read Example
  5. Conclusion

So let’s get started.

1. What is Room, Kotlin, MVVM, Coroutines?

Answer: Let's see what are the important concepts in ROOM and MVVM.

Room Room Database: Database layer on top of SQLite database that takes care of mundane tasks that you used to handle with an SQLiteOpenHelper. Database holder that serves as an access point to the underlying SQLite database. The Room database uses the DAO to issue queries to the SQLite database.

Entity: When working with Architecture Components, this is an annotated class that describes a database table.

SQLite database: On the device, data is stored in an SQLite database. For simplicity, additional storage options, such as a web server, are omitted. The Room persistence library creates and maintains this database for you.

DAO: Data access object. A mapping of SQL queries to functions. You used to have to define these painstakingly in your SQLiteOpenHelper class. When you use a DAO, you call the methods, and Room takes care of the rest.

Kotlin: Kotlin is an open-source, statically-typed programming language that supports both object-oriented and functional programming. Kotlin provides similar syntax and concepts from other languages, including C#, Java, and Scala, among many others. Kotlin does not aim to be unique — instead, it draws inspiration from decades of language development. It exists in variants that target the JVM (Kotlin/JVM), JavaScript (Kotlin/JS), and native code (Kotlin/Native).

MVVM ViewModel: Provides data to the UI. Acts as a communication center between the Repository and the UI. Hides where the data originates from the UI. ViewModel instances survive configuration changes.

LiveData: A data holder class that can be observed. Always holds/caches latest version of data. Notifies its observers when the data has changed. LiveData is lifecycle aware. UI components just observe relevant data and don’t stop or resume observation. LiveData automatically manages all of this since it’s aware of the relevant lifecycle status changes while observing.

Repository: A class that you create, for example using the WordRepository class. You use the Repository for managing multiple data sources.

Coroutines: Coroutines are a great new feature of Kotlin which allow you to write asynchronous code in a sequential fashion. … However, like RxJava, coroutines have a number of little subtleties that you end up learning for yourself during development time, or tricks that you pick up from others.

2. Advantages of Room over SQLite?

  • In case of SQLite, There is no compile time verification of raw SQLite queries. But in Room there is SQL validation at compile time.

  • As your schema changes, you need to update the affected SQL queries manually. Room solves this problem.

  • You need to use lots of boilerplate code to convert between SQL queries and Java data objects. But, Room maps our database objects to Java Object without boilerplate code.

  • Room is built to work with LiveData and RxJava for data observation, while SQLite does not.

3. Important Annotations in Room.

4. Implementation Step-by-Step?

As said before, this example uses MVVM with Room using Kotlin and Coroutines. Let's dive into the steps of doing it.

Step1: Add dependencies to your project:

dependencies {
...
...
    // - - Room Persistence Library
    def room_version = "2.2.5"
    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"

    // - - ViewModel and LiveData
    def lifecycle_version = "2.2.0"
    implementation "androidx.lifecycle:lifecycle-viewmodel-ktx:$lifecycle_version"
    implementation "androidx.lifecycle:lifecycle-livedata-ktx:$lifecycle_version"

    // - - Kotlin Coroutines
    def coroutines_version = "1.3.7"
    implementation "org.jetbrains.kotlinx:kotlinx-coroutines-core:$coroutines_version"
    implementation "org.jetbrains.kotlinx:kotlinx-coroutines-android:$coroutines_version"
...
...
}

Step2: Create different folders that relate to MVVM:

Step3: Design your MainActivity which should look like this:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
   xmlns:app="http://schemas.android.com/apk/res-auto"
   xmlns:tools="http://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:background="#FFFFFF"
   tools:context=".view.MainActivity">

   <androidx.constraintlayout.widget.Guideline
       android:id="@+id/guideline"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:orientation="horizontal"
       app:layout_constraintGuide_percent="0.5" />

   <View
       android:layout_width="0dp"
       android:layout_height="1dp"
       android:background="#8D8D8D"
       app:layout_constraintBottom_toTopOf="@+id/guideline"
       app:layout_constraintEnd_toEndOf="parent"
       app:layout_constraintStart_toStartOf="parent" />

   <androidx.constraintlayout.widget.ConstraintLayout
       android:id="@+id/constraintLayout"
       android:layout_width="0dp"
       android:layout_height="0dp"
       app:layout_constraintBottom_toTopOf="@+id/guideline"
       app:layout_constraintEnd_toEndOf="parent"
       app:layout_constraintStart_toStartOf="parent"
       app:layout_constraintTop_toTopOf="parent">

       <androidx.appcompat.widget.AppCompatTextView
           android:id="@+id/lblInsertHeading"
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:layout_marginTop="20dp"
           android:text="Enter the Username and Password"
           android:textColor="#000000"
           android:textSize="18sp"
           android:textStyle="bold"
           app:layout_constraintEnd_toEndOf="parent"
           app:layout_constraintStart_toStartOf="parent"
           app:layout_constraintTop_toTopOf="parent" />

       <androidx.appcompat.widget.AppCompatEditText
           android:id="@+id/txtUsername"
           android:layout_width="0dp"
           android:layout_height="wrap_content"
           android:textColor="#000000"
           android:hint="Username"
           android:textColorHint="#8D8D8D"
           android:layout_marginTop="20dp"
           android:layout_marginStart="40dp"
           android:layout_marginEnd="40dp"
           app:layout_constraintEnd_toEndOf="parent"
           app:layout_constraintStart_toStartOf="parent"
           app:layout_constraintTop_toBottomOf="@+id/lblInsertHeading" />

       <androidx.appcompat.widget.AppCompatEditText
           android:id="@+id/txtPassword"
           android:layout_width="0dp"
           android:layout_height="wrap_content"
           android:textColor="#000000"
           android:hint="Password"
           android:textColorHint="#8D8D8D"
           android:layout_marginTop="20dp"
           android:layout_marginStart="40dp"
           android:layout_marginEnd="40dp"
           app:layout_constraintEnd_toEndOf="parent"
           app:layout_constraintStart_toStartOf="parent"
           app:layout_constraintTop_toBottomOf="@+id/txtUsername" />

       <androidx.appcompat.widget.AppCompatButton
           android:id="@+id/btnAddLogin"
           android:layout_width="0dp"
           android:layout_height="wrap_content"
           android:layout_marginTop="20dp"
           android:layout_marginStart="40dp"
           android:layout_marginEnd="40dp"
           app:layout_constraintEnd_toEndOf="parent"
           app:layout_constraintStart_toStartOf="parent"
           app:layout_constraintTop_toBottomOf="@+id/txtPassword"
           android:text="Insert Credentials"/>

       <androidx.appcompat.widget.AppCompatTextView
           android:id="@+id/lblInsertResponse"
           android:layout_width="0dp"
           android:layout_height="wrap_content"
           android:text="- - -"
           android:textSize="18sp"
           android:textStyle="bold"
           android:layout_margin="20dp"
           android:gravity="center"
           android:lineSpacingExtra="5dp"
           android:textColor="@android:color/holo_orange_light"
           app:layout_constraintBottom_toBottomOf="parent"
           app:layout_constraintEnd_toEndOf="parent"
           app:layout_constraintStart_toStartOf="parent"
           app:layout_constraintTop_toBottomOf="@+id/btnAddLogin" />

   </androidx.constraintlayout.widget.ConstraintLayout>

   <androidx.constraintlayout.widget.ConstraintLayout
       android:layout_width="0dp"
       android:layout_height="0dp"
       app:layout_constraintBottom_toBottomOf="parent"
       app:layout_constraintEnd_toEndOf="parent"
       app:layout_constraintStart_toStartOf="parent"
       app:layout_constraintTop_toTopOf="@+id/guideline">

       <androidx.appcompat.widget.AppCompatTextView
           android:id="@+id/lblReadHeading"
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:text="Reading and Displaying Data From Room"
           android:textColor="#000000"
           android:textSize="18sp"
           android:textStyle="bold"
           android:layout_marginTop="20dp"
           app:layout_constraintEnd_toEndOf="parent"
           app:layout_constraintStart_toStartOf="parent"
           app:layout_constraintTop_toBottomOf="@+id/btnReadLogin" />

       <androidx.appcompat.widget.AppCompatTextView
           android:id="@+id/lblUseraname"
           android:layout_width="0dp"
           android:layout_height="wrap_content"
           android:text="- - -"
           android:textSize="18sp"
           android:textStyle="bold"
           android:layout_margin="20dp"
           android:gravity="center"
           android:lineSpacingExtra="5dp"
           android:padding="10dp"
           android:textColor="@android:color/holo_orange_light"
           app:layout_constraintEnd_toEndOf="parent"
           app:layout_constraintStart_toStartOf="parent"
           app:layout_constraintTop_toBottomOf="@+id/lblReadHeading" />

       <androidx.appcompat.widget.AppCompatTextView
           android:id="@+id/lblPassword"
           android:layout_width="0dp"
           android:layout_height="wrap_content"
           android:text="- - -"
           android:textSize="18sp"
           android:textStyle="bold"
           android:layout_margin="20dp"
           android:gravity="center"
           android:lineSpacingExtra="5dp"
           android:padding="10dp"
           android:textColor="@android:color/holo_orange_light"
           app:layout_constraintEnd_toEndOf="parent"
           app:layout_constraintStart_toStartOf="parent"
           app:layout_constraintTop_toBottomOf="@+id/lblUseraname" />

       <androidx.appcompat.widget.AppCompatButton
           android:id="@+id/btnReadLogin"
           android:layout_width="0dp"
           android:layout_height="wrap_content"
           android:textSize="12sp"
           android:layout_marginTop="10dp"
           android:layout_marginStart="40dp"
           android:layout_marginEnd="40dp"
           android:text="Click To Read Credentials From Room"
           app:layout_constraintEnd_toEndOf="parent"
           app:layout_constraintStart_toStartOf="parent"
           app:layout_constraintTop_toTopOf="parent" />

       <androidx.appcompat.widget.AppCompatTextView
           android:id="@+id/lblReadResponse"
           android:layout_width="0dp"
           android:layout_height="wrap_content"
           android:layout_margin="20dp"
           android:gravity="center"
           android:lineSpacingExtra="5dp"
           android:text="- - -"
           android:textColor="@android:color/holo_orange_light"
           android:textSize="18sp"
           android:textStyle="bold"
           app:layout_constraintBottom_toBottomOf="parent"
           app:layout_constraintEnd_toEndOf="parent"
           app:layout_constraintStart_toStartOf="parent"
           app:layout_constraintTop_toBottomOf="@+id/lblPassword" />

   </androidx.constraintlayout.widget.ConstraintLayout>

</androidx.constraintlayout.widget.ConstraintLayout>

Step4: Now let's create the Room Database INSTANCE:

LoginDatabase.kt

package com.example.room.mvvm.room

import android.content.Context
import androidx.room.*
import com.example.room.mvvm.model.LoginTableModel

@Database(entities = arrayOf(LoginTableModel::class), version = 1, exportSchema = false)
abstract class LoginDatabase : RoomDatabase() {

    abstract fun loginDao() : DAOAccess

    companion object {

        @Volatile
        private var INSTANCE: LoginDatabase? = null

        fun getDataseClient(context: Context) : LoginDatabase {

            if (INSTANCE != null) return INSTANCE!!

            synchronized(this) {

                INSTANCE = Room
                    .databaseBuilder(context, LoginDatabase::class.java, "LOGIN_DATABASE")
                    .fallbackToDestructiveMigration()
                    .build()

                return INSTANCE!!

            }
        }

    }

}

Step5: Next, let's create a class for creating a Table for Room DB:

package com.example.room.mvvm.model

import androidx.room.ColumnInfo
import androidx.room.Entity
import androidx.room.PrimaryKey

@Entity(tableName = "Login")
data class LoginTableModel (

    @ColumnInfo(name = "username")
    var Username: String,

    @ColumnInfo(name = "password")
    var Password: String

) {

    @PrimaryKey(autoGenerate = true)
    @ColumnInfo(name = "id")
    var Id: Int? = null

}

Step6:


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap