android实体初始化,Android Architecture Components——Room

一、前言

Room是一个持久层库,它可以使我们更加方便的操作SQLite数据库。下面我们介绍它的具体使用。

二、Room的使用介绍

1、创建User实体package com.jilian.androidarchitecture.common;import android.arch.persistence.room.ColumnInfo;import android.arch.persistence.room.Embedded;import android.arch.persistence.room.Entity;import android.arch.persistence.room.Ignore;import android.arch.persistence.room.PrimaryKey;/**

* 实体类

*/@Entity(tableName = "user")public class UserDto {    //主键 自增长

@PrimaryKey(autoGenerate = true)    //表名

@ColumnInfo(name = "id")    private Long id;    @ColumnInfo(name = "sex")    private String sex;    @ColumnInfo(name = "username")    private String username;    @ColumnInfo(name = "password")    private String password;    // 指示 Room 需要忽略的字段或方法

@Ignore

private String age;    //把 info内嵌到 UserDto中

@Embedded

private UserInfo info;    public UserInfo getInfo() {        return info;

}    public void setInfo(UserInfo info) {        this.info = info;

}    public Long getId() {        return id;

}    public void setId(Long id) {        this.id = id;

}    public String getAge() {        return age;

}    public void setAge(String age) {        this.age = age;

}    public String getSex() {        return sex;

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

}    public String getPassword() {        return password;

}    public void setPassword(String password) {        this.password = password;

}    public String getUsername() {        return username;

}    public void setUsername(String username) {        this.username = username;

}    @Override

public String toString() {        return "UserDto{" +                "id=" + id +                ", username='" + username + '\'' +                ", password='" + password + '\'' +                '}';

}

}

下面介绍实体中的注解含义:

@Entity(tableName = "user") 指数据表名为 user

@PrimaryKey(autoGenerate = true) 设置主键,autoGenerate = true 指主键自增长

@ColumnInfo(name = "sex") 列名

@Ignore  需要忽略的字段或方法

@Embedded 把其他实体嵌入到该实体,也就是说,该数据表将拥有其他数据表的属性

2、创建操作数据库的DAOpackage com.jilian.androidarchitecture.dao;import android.arch.lifecycle.LiveData;import android.arch.persistence.room.Dao;import android.arch.persistence.room.Delete;import android.arch.persistence.room.Insert;import android.arch.persistence.room.Query;import android.arch.persistence.room.Update;import com.jilian.androidarchitecture.common.UserDto;import java.util.List;import io.reactivex.Flowable;/**

* 操作数据库的dao层 接口

*/@Daopublic interface UserDao {    /**

* 查询用户列表

* @return

*/

@Query("select * from user")    List findUserList();    /**

* 添加用户

* @param userDtos 可变参数 可以多个

*/

@Insert

void addUser(UserDto...userDtos);    /**

* 根据ID查询用户

* @param ids 可以多个ID 查询多个用户

*/

@Query("select * from user where id in (:ids)")    List findUserById(Long[] ids);    /**

* 更加用户名查询

* @param username

* @return

*/

@Query("select * from user where username = (:username)")     List findUserByName(String username);    /**

* 删除用户

* @param userDtos

*/

@Delete

void deleteUser(UserDto...userDtos);    /**

* 更新用户

* @param userDtos

*/

@Update

void updateUser(UserDto...userDtos);    /**

* 结合 LiveData使用

* @return

*/

@Query("select * from user")

LiveData> findUserListForLiveData();    /**

* 结合RxJava使用

* @return

*/

@Query("select * from user")

Flowable> findUserListFoRxJava();

}

在DAO层我们定义了常规的增删改查的方法,同时我们可以配合LiveData和RxJava一起使用。

3、初始化数据库package com.jilian.androidarchitecture.db;import android.arch.persistence.room.Database;import android.arch.persistence.room.Room;import android.arch.persistence.room.RoomDatabase;import android.content.Context;import com.jilian.androidarchitecture.common.UserDto;import com.jilian.androidarchitecture.common.UserInfo;import com.jilian.androidarchitecture.dao.UserDao;/**

* 创建数据库

*/@Database(entities = {UserDto.class,UserInfo.class},version = 1)public abstract  class AppDataBase  extends RoomDatabase {    private static  AppDataBase appDataBase;    //对外提供需要操作数据库的DAO

public abstract UserDao getUserDao();    /**

* 以单实例的形式初始化数据 并对外提供  AppDataBase实例

* @param context

* @return

*/

public static AppDataBase getInstance(Context context){        if(appDataBase==null){            synchronized (AppDataBase.class){                if(appDataBase==null){                    //"user" 为数据库名

appDataBase = Room.databaseBuilder(context.getApplicationContext(),AppDataBase.class,"user_data").build();

}

}

}        return appDataBase;

}

}

初始化数据库需要创建抽象类并继承RoomDatabase,我们使用Database 注解,并指定相应的实体创建数据表,和数据库版本 version。并在抽象类中创建获取DAO的方法 。//对外提供需要操作数据库的DAO

public abstract UserDao getUserDao();

然后我们通过单实例的方式初始化数据库,并对外提供RoomDatabase实例。/**

* 以单实例的形式初始化数据 并对外提供  AppDataBase实例

* @param context

* @return

*/

public static AppDataBase getInstance(Context context){        if(appDataBase==null){            synchronized (AppDataBase.class){                if(appDataBase==null){                    //"user" 为数据库名

appDataBase = Room.databaseBuilder(context.getApplicationContext(),AppDataBase.class,"user_data").build();

}

}

}        return appDataBase;

}

我们通过RoomDatabase实例可以拿到DAO对象,接着通过DAO对象即可对数据表进行操作。

下面我们通过例子来介绍:

三、实例

创建RoomActivity,分别对数据库进行增删改查的操作package com.jilian.androidarchitecture;import android.arch.lifecycle.LiveData;import android.arch.lifecycle.Observer;import android.os.Bundle;import android.support.annotation.Nullable;import android.support.v7.app.AppCompatActivity;import android.util.Log;import android.view.View;import android.widget.TextView;import com.jilian.androidarchitecture.common.UserDto;import com.jilian.androidarchitecture.db.AppDataBase;import org.reactivestreams.Subscriber;import org.reactivestreams.Subscription;import java.util.List;import io.reactivex.Flowable;import io.reactivex.android.schedulers.AndroidSchedulers;import io.reactivex.schedulers.Schedulers;public class RoomActivity extends AppCompatActivity {    private static final String TAG = "RoomActivity";    private TextView add;    private TextView update;    private TextView delete;    private TextView query;    private TextView queryList;    private TextView queryLiveData;    private TextView queryRxJava;    @Override

protected void onCreate(@Nullable Bundle savedInstanceState) {        super.onCreate(savedInstanceState);

setContentView(R.layout.activity_room);

add = (TextView) findViewById(R.id.add);

update = (TextView) findViewById(R.id.update);

delete = (TextView) findViewById(R.id.delete);

query = (TextView) findViewById(R.id.query);

queryList = (TextView) findViewById(R.id.queryList);

queryLiveData = (TextView) findViewById(R.id.queryLiveData);

queryRxJava = (TextView) findViewById(R.id.queryRxJava);

add.setOnClickListener(new View.OnClickListener() {            @Override

public void onClick(View v) {                new Thread() {                    @Override

public void run() {                        super.run();

UserDto userDto = new UserDto();

userDto.setUsername("daxiaa");

userDto.setPassword("123456");

AppDataBase.getInstance(RoomActivity.this).getUserDao().addUser(userDto);

}

}.start();

}

});

update.setOnClickListener(new View.OnClickListener() {            @Override

public void onClick(View v) {                new Thread() {                    @Override

public void run() {                        super.run();

UserDto userDto = new UserDto();

userDto.setUsername("zaizai");

userDto.setId(1l);

userDto.setPassword("111111");

AppDataBase.getInstance(RoomActivity.this).getUserDao().updateUser(userDto);

}

}.start();

}

});

delete.setOnClickListener(new View.OnClickListener() {            @Override

public void onClick(View v) {                new Thread() {                    @Override

public void run() {                        super.run();

UserDto userDto = new UserDto();

userDto.setId(1l);

AppDataBase.getInstance(RoomActivity.this).getUserDao().deleteUser(userDto);

}

}.start();

}

});

query.setOnClickListener(new View.OnClickListener() {            @Override

public void onClick(View v) {                new Thread() {                    @Override

public void run() {                        super.run();

List list = AppDataBase.getInstance(RoomActivity.this).getUserDao().findUserByName("zaizai");                        for (int i = 0; i 

Log.e(TAG, "user:" + list.get(i).toString());

;

}

}

}.start();

}

});

queryList.setOnClickListener(new View.OnClickListener() {            @Override

public void onClick(View v) {                new Thread() {                    @Override

public void run() {                        super.run();

List list = AppDataBase.getInstance(RoomActivity.this).getUserDao().findUserList();                        for (int i = 0; i 

Log.e(TAG, "user:" + list.get(i).toString());

;

}

}

}.start();

}

});

queryLiveData.setOnClickListener(new View.OnClickListener() {            @Override

public void onClick(View v) {                new Thread() {                    @Override

public void run() {                        super.run();

LiveData> userListForLiveData = AppDataBase.getInstance(RoomActivity.this).getUserDao().findUserListForLiveData();

userListForLiveData.observe(RoomActivity.this, new Observer>() {                            @Override

public void onChanged(@Nullable List list) {                                if (list != null) {                                    for (int i = 0; i 

Log.e(TAG, "user:" + list.get(i).toString());

}

}

}

});

}

}.start();

}

});

queryRxJava.setOnClickListener(new View.OnClickListener() {            @Override

public void onClick(View v) {

Flowable> list = AppDataBase.getInstance(RoomActivity.this).getUserDao().findUserListFoRxJava();                //IO 线程获取数据

list.subscribeOn(Schedulers.io())                        //线程切换

.observeOn(AndroidSchedulers.mainThread()).

subscribe(new Subscriber>() {                            @Override

public void onSubscribe(Subscription s) {                                //  观察者接收事件 = 1个

s.request(1);

}                            @Override

public void onNext(List list) {                                for (int i = 0; i 

Log.e(TAG, "user:" + list.get(i).toString());

}

}                            @Override

public void onError(Throwable t) {

}                            @Override

public void onComplete() {

}

});

}

});

}

}

四、注意

需要注意的是,对SQLite的操作是一个耗时的操作,我们需要在子线程中执行,否则将会抛异常。

作者:大熊啊啊啊

链接:https://www.jianshu.com/p/eac17c60be86

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值