国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

詳細介紹Android-Room數據庫的使用

2019-10-22 18:14:22
字體:
來源:轉載
供稿:網友

前言

Google終于發布了一個和SQLite相關的庫了。之前一直都是在SQLite、XUtils、greenDao、Realm這些數據庫之間來回折騰。現在終于有一個更“正統”數據庫了。

Room是什么?

Room是一個持久性數據庫。

Room持久性庫提供了SQLite的抽象層,以便在充分利用SQLite的同時允許流暢的數據庫訪問。

為什么會選擇Room?

前面我也說到了現在也有不少開源的數據庫給大家使用,那為什么我們還要去學習使用這個庫呢?當然不是我前面說的“正不正統”的原因了。

因為Room有下面幾個優點:

① SQL查詢在編譯時就會驗證 - 在編譯時檢查每個@Query和@Entity等,這就意味著沒有任何運行時錯誤的風險可能會導致應用程序崩潰(并且它不僅檢查語法問題,還會檢查是否有該表)

② 較少的模板代碼

③ 與 LiveData 集成

該如何使用它?

1、在app/build.gradle中添加以下依賴

implementation 'android.arch.persistence.room:runtime:1.0.0'annotationProcessor 'android.arch.persistence.room:compiler:1.0.0'

你可以點擊這里查看最新依賴版本號

2、創建JavaBean

@Entitypublic class User {  @PrimaryKey(autoGenerate = true)//主鍵是否自動增長,默認為false private int id; private String name; private int age; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } //這里的getter/setter方法是必須的 //這里的getter/setter方法是必須的 //這里的getter/setter方法是必須的 //重要的事說三遍}

這里需要使用 @Entity 來注解該類

至少要有一個主鍵 @PrimaryKey

3、創建Dao

接下來,需要為我們的實體創建DAO。 DAO代表數據訪問對象,所以它是告訴我們的數據庫如何操作數據的一種方式:

@Daopublic interface UserDao { @Query("SELECT * FROM user") List<User> getAllUsers(); @Insert void insert(User... users); @Update void update(User... users); @Delete void delete(User... users);}

使用 @Dao 注解該接口

@Insert , @Update , @Delete , @Query 代表我們常用的 插入 、 更新 、 刪除 、 查詢 數據庫操作

@Insert , @Update , @Delete 可以傳入多種不同的參數。例如:

@Insertvoid insert(User... users);@Insertvoid insert(User user);@Insertvoid insert(List<User> userLists);

同理, @Query 也可以返回多種不同的類型。

@Query("SELECT * FROM user")List<User> getAllUsers();@Query("SELECT * FROM user WHERE id=:id")User getUser(int id);@Query("SELECT * FROM user")Cursor getUserCursor();

當然,除了這些我們還可以傳入一些限制符進去。例如,

@Query("SELECT * FROM user WHERE age=:age")List<User> getUsersByAge(int age);@Query("SELECT * FROM user WHERE age=:age LIMIT :max")List<User> getUsersByAge(int max, int... age);

4、創建數據庫

@Database(entities = { User.class }, version = 1,exportSchema = false)public abstract class UserDatabase extends RoomDatabase { private static final String DB_NAME = "UserDatabase.db"; private static volatile UserDatabase instance; static synchronized UserDatabase getInstance(Context context) { if (instance == null) {  instance = create(context); } return instance; } private static UserDatabase create(final Context context) { return Room.databaseBuilder(  context,  UserDatabase.class,  DB_NAME).build(); } public abstract UserDao getUserDao();}

這里使用 @Database 注解該類并添加了 表名 、 數據庫版本 (每當我們改變數據庫中的內容時它都會增加),所以這里使用 exportSchema = false

注意:除了添加表映射的類以及和數據庫版本外,還要添加 exportSchema = false 否則會報警告。

Error:(10, 17) 警告: Schema export directory is not provided to the annotation processor so we cannot export the schema. You can either provide room.schemaLocation annotation processor argument OR set exportSchema to false.

我們抽象了 getUserDao() 方法,這是必要的。

5、使用數據庫

我們終于能夠操作我們的數據庫了。但是所有的操作必須在后臺線程中完成。你可以通過使用 AsyncTask , Thread , Handler , RxJava 或其它方式來完成。

如果沒有在后臺線程執行,并且也沒有說明可以在主線程操作的話,就會報以下錯誤。

Caused by: java.lang.IllegalStateException: Cannot access database on the main thread since it may potentially lock the UI for a long period of time.

例如,我們可以像下面這樣插入數據

User user=new User();user.setName("name1");user.setAge(18);UserDatabase .getInstance(context) .getUserDao() .insert(user);

或者這樣

List<User> allUsers = UserDatabase .getInstance(RoomActivity.this) .getUserDao() .getAllUsers();

好了,基本的使用的方式就這些了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 闸北区| 思南县| 县级市| 五指山市| 汉源县| 内江市| 合肥市| 疏勒县| 攀枝花市| 元阳县| 柳河县| 塘沽区| 金山区| 扎鲁特旗| 惠水县| 山丹县| 铜川市| 邹平县| 永州市| 富裕县| 云林县| 盈江县| 威宁| 竹山县| 潮安县| 东乌| 法库县| 原阳县| 竹山县| 兰考县| 宾川县| 太和县| 秦安县| 万盛区| 修水县| 肇东市| 绿春县| 昂仁县| 彰化县| 富宁县| 乐山市|