===============================================================
Google既然在JitPack中推出了Room,那就说明这个库确实有一定的优势。
Room其实和Retrofit差不多,Room在开发阶段通过注解的方式标记相关功能,编译时自动生成响应的impl实现类。
首先创建一个Android项目,命名为RoomDemo,我的AS是4.2.1。
然后打开app下的build.gradle。在dependencies{}闭包中添加如下依赖:
//room
def room_version = “2.3.0”
implementation “androidx.room:room-runtime:$room_version”
annotationProcessor “androidx.room:room-compiler:$room_version”
这里有两个库一个是依赖库,一个是注解处理器库。2.3.0表示room最新的依赖库版本。
点击Sync进行同步一下。
注解使用,Room使用很简单的,这里有三个基本的使用注解,@Database、@Entity、@Dao。分别对于数据库、表、表的具体操作(增删改查)。
例如创建一个数据表User。先创建包名,在com.llw.roomdemo下创建一个db包,db下创建bean包,bean包下创建User类。
@Entity
public class User {
@PrimaryKey(autoGenerate = true)
@NonNull
public int id;
@ColumnInfo(name = “user_name”, defaultValue = “”)
public String userName;
@ColumnInfo(name = “user_age”)
public int userAge;
@ColumnInfo(name = “nick_name”)
public String nickName;
@ColumnInfo(name = “address”)
public String address;
public User(String userName, int userAge, String nickName, String address) {
this.id = id;
this.userName = userName;
this.userAge = userAge;
this.nickName = nickName;
this.address = address;
}
}
这个类很平常,主要是注解的说明,这个@Entity就是表示数据库中的表,User类对应就是User表,@PrimaryKey表示主键,这里是id,autoGenerate = true 是自增,@NonNull表示不为空。 @ColumnInfo表示表中的列名,name = "user_name"表示列名的值。
Room是对象关系映射型数据库,所以你可以不用写这个@ColumnInfo注解,写它主要是为了设置列名,不写则使用变量名做为列名。
假设我一个表中有30个字段,实际上用到的只有5个,那么另外25个就不需要进行创建了,则使用@Ignore注解进行忽略。
例如这样:
@Ignore
@ColumnIn