当您开始使用Android Room时,下面是一些使用步骤和示例代码供您参考:
添加依赖项:在您的项目的build.gradle文件中,添加以下依赖项以使用Android Room:
// room
def room_version = "2.5.0"
api "androidx.room:room-runtime:$room_version"
annotationProcessor "androidx.room:room-compiler:$room_version"
创建实体类:创建一个用@Entity注解的类来表示数据库中的表,其中每个字段都应该用@ColumnInfo注解进行注释。还可以使用@PrimaryKey和@ForeignKey等注解来定义主键和外键关系。
示例代码:
@Entity(tableName = "users")
data class User(
@PrimaryKey(autoGenerate = true) val id: Int?,
@ColumnInfo(name = "name") val name: String,
@ColumnInfo(name = "age") val age: Int
)
创建DAO接口:创建一个带有对数据库执行操作的接口。使用@Dao注解标记该接口,使用@Query、@Insert、@Update和@Delete等注解定义具体的操作。
示例代码:
@Dao
interface UserDao {
@Query("SELECT * FROM users")
fun getAllUsers(): List<User>
@Query("SELECT * FROM users WHERE id = :userId")
fun getUserById(userId: Int): User
@Insert
fun insertUser(user: User)
@Update
fun updateUser(user: User)
@Delete
fun deleteUser(user: User)
}
创建数据库:创建一个继承自RoomDatabase的抽象类,并在其中声明数据库的实例和具体的DAO接口。使用@Database注解标记该类,并在注解中指定数据库版本号和包含的实体类。
示例代码:
@Database(entities = [User::class], version = 1)
abstract class AppDatabase : RoomDatabase() {
abstract fun userDao(): UserDao
}
初始化数据库:在您的应用程序中的某个地方,通过调用Room.databaseBuilder()方法来构建数据库的实例。
示例代码:
val db = Room.databaseBuilder(
applicationContext,
AppDatabase::class.java, "my-database"
).build()
执行操作:通过访问DAO接口的方法,在数据库上执行具体的操作。
val userDao = db.userDao()
val users = userDao.getAllUsers()
val user = userDao.getUserById(userId)
val newUser = User(null, "John Doe", 25)
userDao.insertUser(newUser)
userDao.updateUser(user)
userDao.deleteUser(user)
这只是Android Room的基本用法示例。您可以根据自己的需求添加更多操作和查询。
关注公众号:Android老皮
解锁 《Android十大板块文档》 ,让学习更贴近未来实战。已形成PDF版
内容如下:
1.Android车载应用开发系统学习指南(附项目实战)
2.Android Framework学习指南,助力成为系统级开发高手
3.2023最新Android中高级面试题汇总+解析,告别零offer
4.企业级Android音视频开发学习路线+项目实战(附源码)
5.Android Jetpack从入门到精通,构建高质量UI界面
6.Flutter技术解析与实战,跨平台首要之选
7.Kotlin从入门到实战,全方面提升架构基础
8.高级Android插件化与组件化(含实战教程和源码)
9.Android 性能优化实战+360°全方面性能调优
10.Android零基础入门到精通,高手进阶之路
敲代码不易,关注一下吧。ღ( ´・ᴗ・` ) 🤔