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
@ColumnInfo(name = “address”)
public String address;
下面在db包下新建一个dao包,创建UserDao,里面的代码如下:
@Dao
public interface UserDao {
/**
-
增加
-
@param users 用户
*/
@Insert(onConflict = OnConflictStrategy.REPLACE)
void insertUser(User… users);
/**
-
查询所有用户
-
@return 用户列表
*/
@Query(“SELECT * FROM user”)
List queryAll();
/**
-
按用户名查询
-
@param userName 用户名
-
@return 用户
*/
@Query(“SELECT * FROM user WHERE user_name LIKE :userName LIMIT 1”)
User findByName(String userName);
/**
-
修改
-
@param user 根据用户进行修改
*/
@Update
void update(User user);
/**
-
删除
-
@param user 根据用户进行删除
*/