Logo

dev-resources.site

for different kinds of informations.

Understanding Room Database in Android: A Beginner's Guide

Published at
1/4/2025
Categories
android
kotlin
mobile
beginners
Author
harsh_lade
Categories
4 categories in total
android
open
kotlin
open
mobile
open
beginners
open
Author
10 person written this
harsh_lade
open
Understanding Room Database in Android: A Beginner's Guide

Introduction

Room Database is an essential topic in Android Development, enabling developers to store and manage data efficiently. It acts as an abstraction layer over SQLite, simplifying database operations and making data management more developer-friendly. In this article, we will explore Room Database step by step, with practical examples to help you understand its implementation.


Why to use Room Database

  • Abstraction Layer: Room provides an abstraction layer over SQLite, allowing developers to write simpler and more idiomatic Kotlin code.
  • Compile-Time Verification: Room validates queries and schema definitions at compile time, reducing runtime errors and enhancing reliability.

Key Concepts/Terminologies

  • Entities: Represents table in your Database.
  • Dao (Data Access Object): Defines the operations with the Database.
  • Database: Acts as the database holder and contains all the tables.

Step-by-Step Implementation.

Let’s walk through the implementation process using an example of a User Database.

Step 1: Add Plugin

To get started, you need to add a pluginβ€”either kapt or ksp. This plugin will help the compiler to understand the quotations that we will use.

  • ksp (Kotlin Symbol Processing): Faster and more efficient for annotation processing.
  • kapt (Kotlin Android Processing Tool): Traditional and widely used.

You can choose either ksp or kapt.
If you want to learn about ksp and kapt then you can refer to the official documentation. For now, you can continue.
In this example, we will use kapt.

  • Adding Kapt

Open your build.gradle.kts (module level) and add the following line inside plugins block:

plugins {
    alias(libs.plugins.android.application)
    alias(libs.plugins.jetbrains.kotlin.android)

    id("kotlin-kapt") // Add this line
}
Enter fullscreen mode Exit fullscreen mode
  • Adding ksp

Open build.gradle.kts (project level) in you project files. Here you have to add plugin for ksp.

plugins {
    //other plugins...

    //Your to add this. The version should be same as your kotlin (for first). 
    //For eg. you have kotlin version 1.9.22 then the version for ksp plugin should be 1.9.22-x.x.x
    id("com.google.devtools.ksp") version "1.9.22-1.0.17" apply false
}
Enter fullscreen mode Exit fullscreen mode

Now, open you build.gradle.kts (module level) add this line in plugins block:

plugins {
    alias(libs.plugins.android.application)
    alias(libs.plugins.jetbrains.kotlin.android)

    id("com.google.devtools.ksp") // Add this line
}
Enter fullscreen mode Exit fullscreen mode

Sync your project after adding the plugin.


Step 2: Add Dependencies

Add the required dependencies for Room in your build.gradle.kts (module level) file:

dependencies{
    implementation("androidx.room:room-runtime:2.6.1") 
    //For Kotlin extension coroutines for room.
    implementation("androidx.room:room-ktx:2.6.1")
    //To use kotlin annotation processor.
    kapt("androidx.room:room-compiler:2.6.1")
}
Enter fullscreen mode Exit fullscreen mode

Ensure you use the latest versions of these dependencies. After adding these dependencies, sync your project.


Step 3: Creating your First Table/Entity

Create the First Table inside the Database. To create one, define a data class annotate it with @Entity and give a name. Each entity must have at least one primary key annotate by @PrimaryKey, you can set it to auto-generate so it will get generated automatically.

@Entity(tableName="user_table")
data class User(
    @PrimaryKey(autoGenerate = true) val id:Int, //Define a primary key in table
    val name:String,
    val contact:Long
)
Enter fullscreen mode Exit fullscreen mode

Step 4: Define a DAO Interface

DAO (Data Object Interface) defines the operations you can perform on the database such as:

  • Insert
  • Delete
  • Query
  • Update

Create an interface annotate it by @Dao and give it a name (UserDao, in this case).

@Dao
interface UserDao {
    @Insert //Define more methods as per your use
    suspend fun insert(user: User)

    //we can write any SQL query.
    @Query("select * from user_table order by id ASC")
    fun getData(): Flow<List<User>>
}
Enter fullscreen mode Exit fullscreen mode

Here, getAllUsers() retrieves all users from the user_table in ascending order.


Step 5: Define a Database

Now, we will implement a database. Create an abstract class that will implement RoomDataBase(). Annotate it by @Database inside the annotation you will have to give all the Table/Entity names you are using and a version (we will update this version if we want to update anything in our database).

example:

@Database(entities = [User::class], version = 1)
abstract class AppDatabase : RoomDatabase() {
    abstract fun userDao(): UserDao
}
Enter fullscreen mode Exit fullscreen mode

Step 6: Initializing Room

Finally, initialize the Room database in your application. Use the Room.databaseBuilder() method to create an instance.

val db=Room.databaseBuilder(
    context,
    AppDatabase::class.java, //We have to give our database class (abstract class in step 5)
    "app_database" //you can give any name to database.
).build()
val userDao=db.userDao()//It is our dao.
Enter fullscreen mode Exit fullscreen mode

Conclusion

In this article, we explored the fundamentals of Room Database, including adding plugins, dependencies, entities, DAOs, and initializing the database. In the next article, we will learn how to perform operations such as adding and retrieving data from the database.

Stay tuned for more practical insights into Android Development!

android Article's
30 articles in total
Favicon
Three Common Pitfalls in Modern Android Development
Favicon
Using SVGs on Canvas with Compose Multiplatform
Favicon
Kotlin Generics Simplified
Favicon
Understanding Process Management in Operating Systems
Favicon
Introduction to Operating Systems
Favicon
Why Should You Develop a Native Android App Over Flutter?
Favicon
Flutter Development for Low end PCs
Favicon
Day 13 of My Android Adventure: Crafting a Custom WishList App with Sir Denis Panjuta
Favicon
How to Integrate Stack, Bottom Tab, and Drawer Navigator in React Native
Favicon
Flutter Design Pattern Bussines Logic Component (BLOC)
Favicon
🌎 Seamless Multi-Language Support in React Native
Favicon
Morphing Geometric Shapes with SDF in GLSL Fragment Shaders and Visualization in Jetpack Compose
Favicon
FMWhatsApp - Enhanced WhatsApp Experience
Favicon
[Feedback Wanted]Meet Nora: A Desktop Plant Robot Companion 🌱
Favicon
GBWhatsApp - Advanced WhatsApp Alternative
Favicon
Android TreeView(Hierarchy based) with Kotlin
Favicon
The Role of Android in IoT Development
Favicon
PicsArt MOD APK: Unlock the Power of Creativity
Favicon
Getting Started with Android Testing: Building Reliable Apps with Confidence (Part 3/3)
Favicon
How to Integrate Stack and Bottom Tab Navigator in React Native
Favicon
Day 11 Unlocking the Magic of Location Services!
Favicon
Creating M3U Playlists for xPola Player
Favicon
xPola Player: The Advanced Media Player for Android
Favicon
Getting Started with Android Testing: Building Reliable Apps with Confidence (Part 2/3)
Favicon
How I wrote this technical post with Nebo: an Android gamechanger ✍️
Favicon
Understanding Room Database in Android: A Beginner's Guide
Favicon
hiya
Favicon
Android Lock Screen Widgets: Revolutionizing Content Consumption with Glance's Smart Features
Favicon
Top 10 Best Android App Development Companies in India
Favicon
Why Modded APKs Are Gaining Popularity in 2025: Understanding the Risks and Benefits

Featured ones: