Android Room SQLITE 更新自定义查询与MVVM
创始人
2024-08-15 10:30:17
0

下面是一个简单的示例,展示了如何在Android Room SQLite中使用自定义查询与MVVM模式。

首先,在build.gradle文件中添加以下依赖项:

implementation 'androidx.room:room-runtime:2.3.0'
kapt 'androidx.room:room-compiler:2.3.0'

接下来,创建一个实体类(Entity):

@Entity(tableName = "users")
data class User(
    @PrimaryKey val id: Int,
    val name: String,
    val age: Int
)

然后,创建一个数据访问对象(DAO):

@Dao
interface UserDao {
    @Query("SELECT * FROM users")
    fun getAllUsers(): LiveData>

    @Query("SELECT * FROM users WHERE age > :minAge")
    fun getUsersByAge(minAge: Int): LiveData>

    @Insert(onConflict = OnConflictStrategy.REPLACE)
    suspend fun insertUser(user: User)

    @Delete
    suspend fun deleteUser(user: User)
}

接下来,创建一个数据库类:

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

    companion object {
        @Volatile
        private var INSTANCE: AppDatabase? = null

        fun getDatabase(context: Context): AppDatabase {
            return INSTANCE ?: synchronized(this) {
                val instance = Room.databaseBuilder(
                    context.applicationContext,
                    AppDatabase::class.java,
                    "app_database"
                ).build()
                INSTANCE = instance
                instance
            }
        }
    }
}

然后,创建一个仓库类:

class UserRepository(private val userDao: UserDao) {
    val allUsers: LiveData> = userDao.getAllUsers()

    fun getUsersByAge(minAge: Int): LiveData> {
        return userDao.getUsersByAge(minAge)
    }

    suspend fun insertUser(user: User) {
        userDao.insertUser(user)
    }

    suspend fun deleteUser(user: User) {
        userDao.deleteUser(user)
    }
}

接下来,创建一个ViewModel类:

class UserViewModel(private val userRepository: UserRepository) : ViewModel() {
    val allUsers: LiveData> = userRepository.allUsers

    fun getUsersByAge(minAge: Int): LiveData> {
        return userRepository.getUsersByAge(minAge)
    }

    fun insertUser(user: User) {
        viewModelScope.launch(Dispatchers.IO) {
            userRepository.insertUser(user)
        }
    }

    fun deleteUser(user: User) {
        viewModelScope.launch(Dispatchers.IO) {
            userRepository.deleteUser(user)
        }
    }
}

最后,在Activity或Fragment中使用ViewModel来获取和操作数据:

class MainActivity : AppCompatActivity() {
    private lateinit var userViewModel: UserViewModel

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

        val userDao = AppDatabase.getDatabase(application).userDao()
        val userRepository = UserRepository(userDao)
        userViewModel = ViewModelProvider(this, UserViewModelFactory(userRepository)).get(UserViewModel::class.java)

        // 获取所有用户
        userViewModel.allUsers.observe(this, { users ->
            // 更新UI
        })

        // 获取年龄大于20的用户
        userViewModel.getUsersByAge(20).observe(this, { users ->
            // 更新UI
        })

        // 插入新用户
        val newUser = User(1, "John Doe", 25)
        userViewModel.insertUser(newUser)

        // 删除用户
        userViewModel.deleteUser(newUser)
    }
}

这就是一个简单的使用Android Room SQLite进行自定义查询与MVVM的示例。你可以根据自己的需求进行修改和扩展。

相关内容

热门资讯

揭秘真相!微扑克ai辅助器苹果... 揭秘真相!微扑克ai辅助器苹果版,雀神外挂怎么开,微信上微乐麻将是不是有挂呀(有挂技巧)在进入微信上...
重大消息!governorof... 重大消息!governorofpoker3有挂,红河全民雀神有挂吗,天天爱掼蛋辅助(有挂介绍);1、...
必知教程!微扑克ai机器人,七... 必知教程!微扑克ai机器人,七彩云南游戏辅助器,流年众娱有挂吗(有挂解密)1)七彩云南游戏辅助器辅助...
重大通报!微扑克真的有挂,雀神... 重大通报!微扑克真的有挂,雀神小程序辅助app下载,财神13张牌的规律(有挂插件);1、玩家可以在财...
最新通报!wepoke软件机器... 最新通报!wepoke软件机器人,广东雀神小程序老是输,上海哈灵辅助器免费(有挂插件)上海哈灵辅助器...
查到实测辅助!德州全自动辅助,... 查到实测辅助!德州全自动辅助,雀神小程序辅助app,山西扣点点外挂是不是真的(有挂脚本)小薇(透视辅...
科技分享!wepoke辅助真的... 科技分享!wepoke辅助真的,广东雀神辅助插件如何下载,白金岛跑得快辅助器(有挂插件)1、操作简单...
三分钟了解!wpk真的有挂,广... 三分钟了解!wpk真的有挂,广东雀神免费智能辅助下载,杭州都莱游戏有外 挂吗(有挂辅助)1、起透看视...
我来向大家传授!wpk德州伙牌... 我来向大家传授!wpk德州伙牌打法,雀神广东麻雀辅助器,蜜瓜大厅辅助怎么买(有挂介绍)1、蜜瓜大厅辅...
六分钟了解!红龙扑克机制,雀神... 六分钟了解!红龙扑克机制,雀神广东麻将输赢规律讲解,哈糖大菠萝(有挂脚本)1、构建自己的哈糖大菠萝辅...