Skip to main content

How to load data from a database into a ListView in Kotlin Android

How to load data from a database into a ListView in Kotlin Android.

Here is a detailed step-by-step tutorial on how to load data from a database into a ListView in Kotlin Android:

Step 1: Set up the project

Create a new Android project in Android Studio. Make sure you have the latest version of Kotlin and Android SDK installed.

Step 2: Add necessary dependencies

In your project's build.gradle file, add the following dependencies:

dependencies {
implementation 'androidx.appcompat:appcompat:1.2.0'
implementation 'androidx.recyclerview:recyclerview:1.1.0'
implementation 'androidx.room:room-runtime:2.2.5'
kapt 'androidx.room:room-compiler:2.2.5'
}

Step 3: Create the database

Create a new Kotlin class called AppDatabase. This class will be responsible for creating and managing the database. Use the Room library to simplify the database operations.

import androidx.room.Database
import androidx.room.RoomDatabase

@Database(entities = [Item::class], version = 1)
abstract class AppDatabase : RoomDatabase() {
abstract fun itemDao(): ItemDao
}

Step 4: Create the data model

Create a new Kotlin class called Item. This class represents the data model for each item in the database.

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

@Entity(tableName = "items")
data class Item(
@PrimaryKey(autoGenerate = true)
val id: Int,
val name: String,
val description: String
)

Step 5: Create the data access object (DAO)

Create a new Kotlin interface called ItemDao. This interface will define the database operations for manipulating the Item objects.

import androidx.room.Dao
import androidx.room.Insert
import androidx.room.Query

@Dao
interface ItemDao {
@Query("SELECT * FROM items")
fun getAllItems(): List<Item>

@Insert
fun insertItem(item: Item)
}

Step 6: Create the adapter

Create a new Kotlin class called ItemAdapter. This class will be responsible for binding the data to the ListView.

import android.content.Context
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.BaseAdapter
import kotlinx.android.synthetic.main.list_item.view.*

class ItemAdapter(private val context: Context, private val items: List<Item>) : BaseAdapter() {

override fun getCount(): Int {
return items.size
}

override fun getItem(position: Int): Any {
return items[position]
}

override fun getItemId(position: Int): Long {
return position.toLong()
}

override fun getView(position: Int, convertView: View?, parent: ViewGroup?): View {
val view = convertView ?: LayoutInflater.from(context).inflate(R.layout.list_item, parent, false)

val item = items[position]

view.itemName.text = item.name
view.itemDescription.text = item.description

return view
}
}

Step 7: Load data into the ListView

In your activity or fragment, create an instance of the AppDatabase and retrieve the ItemDao. Then, use the getAllItems method to fetch the items from the database. Finally, create an instance of the ItemAdapter and set it as the adapter for the ListView.

import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity
import kotlinx.android.synthetic.main.activity_main.*

class MainActivity : AppCompatActivity() {

private lateinit var itemAdapter: ItemAdapter

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)

val database = Room.databaseBuilder(applicationContext, AppDatabase::class.java, "my-database").build()
val itemDao = database.itemDao()

val items = itemDao.getAllItems()

itemAdapter = ItemAdapter(this, items)
listView.adapter = itemAdapter
}
}

That's it! You have successfully loaded data from a database into a ListView in Kotlin Android. Run your app and you should see the list of items displayed in the ListView.

Note: Make sure to replace the placeholder code (e.g., R.layout.list_item, R.layout.activity_main) with your actual layout resources.

I hope this tutorial helps you! Let me know if you have any questions.