Room数据库

Room数据库


1.Room使用

Step1:Gradle文件的dependencies中添加以下代码
//room数据库
compile "android.arch.persistence.room:runtime:1.1.0-beta2"                     
annotationProcessor "android.arch.persistence.room:compiler:1.1.0-beta2"
//rxjava2对room支持
compile "android.arch.persistence.room:rxjava2:1.1.0-beta2"                     

Step2:创建实体类文件,比如UserModel.java

import android.arch.persistence.room.ColumnInfo;
import android.arch.persistence.room.Entity;
import android.arch.persistence.room.Ignore;
import android.arch.persistence.room.PrimaryKey;
import android.support.annotation.NonNull;

@Entity(tableName = "user_table")       //数据表名字user_table
public class UserModel {

    @PrimaryKey(autoGenerate = false)   //主键,自动增长=false
    @ColumnInfo(name = "user_id")       //userId数据表字段为user_id
    @NonNull                            //主键设置为非空
    private String userId;              //用户id

    @ColumnInfo(name = "user_name")     //userName数据表字段为user_name,默认允许空值
    private String userName;            //用户名(公司或个人姓名)

    @ColumnInfo(name = "user_pet_name")
    private String userPetName;         //用户呢称(系统生成,之后可以修改)

    @ColumnInfo(name = "user_phone")
    private String userPhone;           //用户电话

    @ColumnInfo(name = "user_icon")
    private String userIcon;            //用户头像

    @ColumnInfo(name = "vip_type")
    private int vipType;                //用户vip类型

    @ColumnInfo(name = "create_time")
    private long createTime;            //用户注册时间

    @ColumnInfo(name = "sex")
    private int sex;                    //用户性别 1-->男 2-->女

    @ColumnInfo(name = "integral")
    private double integral;            //积分

    @ColumnInfo(name = "id_card_number")
    private String idCardNumber;        //身份证号

    @ColumnInfo(name = "email")
    private String email;               //用户邮箱

    @ColumnInfo(name = "status")
    private int status;                 //用户状态 0-->禁用  1-->正常

    public UserModel() {                //Room调用的构造函数

    }

    @Ignore                             //有2个构造函数,让Room忽略掉这个,使用上面一个构造函数
    public UserModel(String userIcon, String userName) {
        this.userIcon = userIcon;
        this.userName = userName;
    }

    @Override
    public String toString() {
        return "UserModel{" +
                "userId='" + userId + '\'' +
                ", userName='" + userName + '\'' +
                ", userPetName='" + userPetName + '\'' +
                ", userPhone='" + userPhone + '\'' +
                ", userIcon='" + userIcon + '\'' +
                ", vipType=" + vipType +
                ", createTime=" + createTime +
                ", sex=" + sex +
                ", integral=" + integral +
                ", idCardNumber='" + idCardNumber + '\'' +
                ", email='" + email + '\'' +
                ", status=" + status +
                '}';
    }

    //=================================================================
    //  以为字段设置成private,提供get\set方法给room使用
    //=================================================================
    public String getUserId() {
        return userId;
    }

    public void setUserId(String userId) {
        this.userId = userId;
    }

    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }

    public String getUserPetName() {
        return userPetName;
    }

    public void setUserPetName(String userPetName) {
        this.userPetName = userPetName;
    }

    public String getUserPhone() {
        return userPhone;
    }

    public void setUserPhone(String userPhone) {
        this.userPhone = userPhone;
    }

    public String getUserIcon() {
        return userIcon;
    }

    public void setUserIcon(String userIcon) {
        this.userIcon = userIcon;
    }

    public int getVipType() {
        return vipType;
    }

    public void setVipType(int vipType) {
        this.vipType = vipType;
    }

    public long getCreateTime() {
        return createTime;
    }

    public void setCreateTime(long createTime) {
        this.createTime = createTime;
    }

    public int getSex() {
        return sex;
    }

    public String getSexString() {
        return getSex() == 1 ? Util.getString(R.string.man) : Util.getString(R.string.woman);
    }

    public void setSex(int sex) {
        this.sex = sex;
    }

    public double getIntegral() {
        return integral;
    }

    public void setIntegral(double integral) {
        this.integral = integral;
    }

    public String getIdCardNumber() {
        return idCardNumber;
    }

    public void setIdCardNumber(String idCardNumber) {
        this.idCardNumber = idCardNumber;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public int getStatus() {
        return status;
    }

    public void setStatus(int status) {
        this.status = status;
    }
}
Step3:创建Dao层
import android.arch.persistence.room.Dao;
import android.arch.persistence.room.Delete;
import android.arch.persistence.room.Insert;
import android.arch.persistence.room.OnConflictStrategy;
import android.arch.persistence.room.Query;

import io.reactivex.Flowable;

//Dao层用@Dao标识
@Dao    
public interface UserModelDao {

    //查询语句
    @Query("SELECT * FROM user_table WHERE user_id = :id")
    Flowable<UserModel> getUserModel(String id);

    //插入,onConflict = OnConflictStrategy.REPLACE表示插入有冲突时候替代
    @Insert(onConflict = OnConflictStrategy.REPLACE)
    void insert(UserModel userModel);

    @Delete
    void delete(UserModel userModel);
}
Step4:创建提供Dao层的抽象类,继承RoomDatabase
import android.arch.persistence.room.Database;
import android.arch.persistence.room.Room;
import android.arch.persistence.room.RoomDatabase;

//创建一个抽象类。用@Database标识,表示是RoomDatabase
//entities = {UserModel.class},表示数据库存储的实体类有UserModel
//version = 1,表示数据库版本号为1
@Database(entities = {UserModel.class}, version = 1)
public abstract class AppDatabase extends RoomDatabase {

    //抽象方法,提供UserModelDao
    public abstract UserModelDao getUserModelDao();

    //单例
    private static volatile AppDatabase instance;

    //获取单例
    public static AppDatabase getInstance() {
        if (instance == null) {
            synchronized (AppDatabase.class) {
                if (instance == null) {
                    //Room为我们实现抽象类
                    instance = Room.databaseBuilder(Util.getApplication(),
                            AppDatabase.class,
                            Constant.DATABASE_NAME).build();
                }
            }
        }
        return instance;
    }
}
Step5:使用
AppDatabase.getInstance()
                .getUserModelDao()
                .insert(userModel);

常见问题

  • 无法import RoomDatabase
    • 因为RoomDatabase需要com.android.support在26.0.1之后
    • 项目中com.android.support修改为26.0.1之后就可以了
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容