Android Room的简单使用

Room简单使用

Room是一个持久性数据库,Room持久层库在SQLite上提供了一个抽象层,以便充分利用SQLite的强大功能同时,能够流畅地访问数据库,具有以下优势:

  • 针对SQL查询的编译时验证
  • 可最大限度减少重复和容易出错的样板代码的方便注解
  • 简化了数据库迁移路径

Room的三个部分

  • 数据库:用于保存数据库,并作为应用持久性数据底层连接的主要访问
  • 数据实体:用于表示数据库中的表
  • 数据访问对象(DAO):用于增删改查的数据方法

添加依赖

dependencies {
    def room_version = "2.4.2"

    implementation "androidx.room:room-runtime:$room_version"
    annotationProcessor "androidx.room:room-compiler:$room_version"

    // optional - RxJava2 support for Room
    implementation "androidx.room:room-rxjava2:$room_version"

    // optional - RxJava3 support for Room
    implementation "androidx.room:room-rxjava3:$room_version"

    // optional - Guava support for Room, including Optional and ListenableFuture
    implementation "androidx.room:room-guava:$room_version"

    // optional - Test helpers
    testImplementation "androidx.room:room-testing:$room_version"

    // optional - Paging 3 Integration
    implementation "androidx.room:room-paging:2.5.0-alpha01"
}

创建数据实体-即数据表

  • @Entity(tableName = “表名”):设置表名
  • @PrimaryKey(autoGenerate = false):当设置为true,让sqlite生成唯一的ID(即添加一个主键)
  • @Entity(primaryKeys = {“username”, “age”}):添加多个主键
  • @Ignore:忽略某个字段
//指定表名,默认情况下表名为类的名字,可使用tableName指定表名
@Entity
public class User {
    //指定id为主键,并自增
    @PrimaryKey(autoGenerate = true)
    public int id;

    //表示这个字段为一列,默认情况下类名为列名,也可以使用name属性指定列名
    @ColumnInfo(name = "username")
    public String username;

    @ColumnInfo(name = "age")
    public int age;
    
    //忽略这个字段
    @Ignore
    Bitmap image;
}

注意:SQLite的表名和列名不区分大小写

创建数据访问对象(DAO)-即访问数据库的方法

  • @DAO:指定数据访问对象
  • @Insert:插入数据
  • @Delete:删除数据
  • @Update:更新数据
  • @Query:查询数据
//指定数据访问对象DAO
@Dao
public interface UserDao {

    //插入数据
    @Insert
    void insert(User user);

    //删除数据
    @Delete
    void delete(User user);

    //更新数据
    @Update
    void update(User user);
    
    //获取所有用户数据
    @Query("select * from user")
    List<User> getUserAll();

    //查找指定的数据
    @Query("select * from user where username = :username and age = :age")
    List<User> getUserInfo(String username, int age);
}

创建数据库类

//指定数据实体类和版本号
@Database(entities = {User.class}, version = 1)
public abstract class AppDatabase extends RoomDatabase {
    //提供返回一个数据访问对象的方法
    public abstract UserDao userDao();
}

创建并使用

AppDatabase database = Room.databaseBuilder(getApplicationContext(), AppDatabase.class, "test.db").build();
UserDao userDao = database.userDao();
List<User> userDataAll = userDao.getUserAll();
for (User user : userDataAll) {
    Log.e("TAG", "id: " + user.id);
    Log.e("TAG", "username: " + user.username);
    Log.e("TAG", "age: " + user.age);
}

你可能感兴趣的:(Android,android,android,jetpack)