Android-Room數(shù)據(jù)庫(kù)的使用方法教程
Room是一個(gè)持久性數(shù)據(jù)庫(kù),提供了SQLite的抽象層,以便在充分利用SQLite的同時(shí)允許流暢的數(shù)據(jù)庫(kù)訪(fǎng)問(wèn)。這篇文章主要介紹了詳細(xì)介紹Android-Room數(shù)據(jù)庫(kù)的使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧。
為什么會(huì)選擇Room?
前面我也說(shuō)到了現(xiàn)在也有不少開(kāi)源的數(shù)據(jù)庫(kù)給大家使用,那為什么我們還要去學(xué)習(xí)使用這個(gè)庫(kù)呢?當(dāng)然不是我前面說(shuō)的“正不正統(tǒng)”的原因了。
因?yàn)镽oom有下面幾個(gè)優(yōu)點(diǎn):
?、?SQL查詢(xún)?cè)诰幾g時(shí)就會(huì)驗(yàn)證 - 在編譯時(shí)檢查每個(gè)@Query和@Entity等,這就意味著沒(méi)有任何運(yùn)行時(shí)錯(cuò)誤的風(fēng)險(xiǎn)可能會(huì)導(dǎo)致應(yīng)用程序崩潰(并且它不僅檢查語(yǔ)法問(wèn)題,還會(huì)檢查是否有該表)
?、?較少的模板代碼
?、?與 LiveData 集成
該如何使用它?
1、在app/build.gradle中添加以下依賴(lài)
implementation 'android.arch.persistence.room:runtime:1.0.0'
annotationProcessor 'android.arch.persistence.room:compiler:1.0.0'
你可以點(diǎn)擊這里查看最新依賴(lài)版本號(hào)
2、創(chuàng)建JavaBean
@Entity
public class User {
@PrimaryKey(autoGenerate = true)//主鍵是否自動(dòng)增長(zhǎng),默認(rèn)為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方法是必須的
}
這里需要使用 @Entity 來(lái)注解該類(lèi)
至少要有一個(gè)主鍵 @PrimaryKey
3、創(chuàng)建Dao
接下來(lái),需要為我們的實(shí)體創(chuàng)建DAO。 DAO代表數(shù)據(jù)訪(fǎng)問(wèn)對(duì)象,所以它是告訴我們的數(shù)據(jù)庫(kù)如何操作數(shù)據(jù)的一種方式:
@Dao
public interface UserDao {
@Query("SELECT * FROM user")
List getAllUsers();
@Insert
void insert(User... users);
@Update
void update(User... users);
@Delete
void delete(User... users);
}
使用 @Dao 注解該接口
@Insert , @Update , @Delete , @Query 代表我們常用的 插入 、 更新 、 刪除 、 查詢(xún) 數(shù)據(jù)庫(kù)操作
@Insert , @Update , @Delete 可以傳入多種不同的參數(shù)。例如:
@Insert
void insert(User... users);
@Insert
void insert(User user);
@Insert
void insert(List userLists);
同理, @Query 也可以返回多種不同的類(lèi)型。
@Query("SELECT * FROM user")
List getAllUsers();
@Query("SELECT * FROM user WHERE id=:id")
User getUser(int id);
@Query("SELECT * FROM user")
Cursor getUserCursor();
當(dāng)然,除了這些我們還可以傳入一些限制符進(jìn)去。例如,
@Query("SELECT * FROM user WHERE age=:age")
List getUsersByAge(int age);
@Query("SELECT * FROM user WHERE age=:age LIMIT :max")
List getUsersByAge(int max, int... age);
4、創(chuàng)建數(shù)據(jù)庫(kù)
@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 注解該類(lèi)并添加了 表名 、 數(shù)據(jù)庫(kù)版本 (每當(dāng)我們改變數(shù)據(jù)庫(kù)中的內(nèi)容時(shí)它都會(huì)增加),所以這里使用 exportSchema = false
注意:除了添加表映射的類(lèi)以及和數(shù)據(jù)庫(kù)版本外,還要添加 exportSchema = false 否則會(huì)報(bào)警告。
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、使用數(shù)據(jù)庫(kù)
我們終于能夠操作我們的數(shù)據(jù)庫(kù)了。但是所有的操作必須在后臺(tái)線(xiàn)程中完成。你可以通過(guò)使用 AsyncTask , Thread , Handler , RxJava 或其它方式來(lái)完成。
如果沒(méi)有在后臺(tái)線(xiàn)程執(zhí)行,并且也沒(méi)有說(shuō)明可以在主線(xiàn)程操作的話(huà),就會(huì)報(bào)以下錯(cuò)誤。
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.
例如,我們可以像下面這樣插入數(shù)據(jù)
User user=new User();
user.setName("name1");
user.setAge(18);
UserDatabase
.getInstance(context)
.getUserDao()
.insert(user);
或者這樣
List allUsers = UserDatabase
.getInstance(RoomActivity.this)
.getUserDao()
.getAllUsers();
好了,基本的使用的方式就這些了。
補(bǔ)充:MySQL 數(shù)據(jù)庫(kù)常用命令
create database name; 創(chuàng)建數(shù)據(jù)庫(kù)
use databasename; 進(jìn)入數(shù)據(jù)庫(kù)
drop database name 直接刪除數(shù)據(jù)庫(kù),不提醒
show tables; 顯示表
describe tablename; 查看表的結(jié)構(gòu)
select 中加上distinct去除重復(fù)字段
mysqladmin drop databasename 刪除數(shù)據(jù)庫(kù)前,有提示。
顯示當(dāng)前mysql版本和當(dāng)前日期
select version(),current_date;
數(shù)據(jù)庫(kù)維護(hù)方法
在MySQL使用的過(guò)程中,在系統(tǒng)運(yùn)行一段時(shí)間后,可能會(huì)產(chǎn)生碎片,造成空間的浪費(fèi),所以有必要定期的對(duì)MySQL進(jìn)行碎片整理。
當(dāng)刪除id=2的記錄時(shí)候,發(fā)生的現(xiàn)象
這個(gè)時(shí)候發(fā)現(xiàn)磁盤(pán)的空間并沒(méi)有減少。這種現(xiàn)象就叫做碎片化(有一部分的磁盤(pán)空間在數(shù)據(jù)刪除以后(空),還是無(wú)法被操作系統(tǒng)所使用。)
常見(jiàn)的優(yōu)化:
# alter table xxx engine myisam;
# optimize table t1;
注意: 在實(shí)際開(kāi)發(fā)的過(guò)程中,上面兩個(gè)語(yǔ)句盡量少使用,因?yàn)樵谑褂玫倪^(guò)程中,MySQL的表的結(jié)構(gòu)會(huì)整體全部重新整理,需要消耗很多的資源,建議在凌晨?jī)扇c(diǎn)鐘的時(shí)候執(zhí)行。(在linux下有定時(shí)器腳本可以執(zhí)行,crontab)
數(shù)據(jù)庫(kù)相關(guān)文章:
1.excel怎么將表格連入數(shù)據(jù)庫(kù)
2.把Excel數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫(kù)的方法