真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Androidbdflow數(shù)據(jù)庫神器的使用

今日觀看別人源碼的時候偶然間發(fā)現(xiàn)了一個很好用的數(shù)據(jù)庫神器,在這里分享一下。

成都創(chuàng)新互聯(lián)公司專注于拉孜企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,商城網(wǎng)站定制開發(fā)。拉孜網(wǎng)站建設(shè)公司,為拉孜等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站制作,專業(yè)設(shè)計,全程項目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)

什么是dbflow?

dbflow是Android SQLite ORM的一個使用注解操控的工具庫。簡單說就是對sqlite數(shù)據(jù)庫進行操作的一個java庫。

ORM(Object-relational mapping),中文翻譯為對象關(guān)系映射,是一種為了解決面向?qū)ο笈c關(guān)系數(shù)據(jù)庫存在的互不匹配的現(xiàn)象的技術(shù)。簡單的說,ORM是通過使用描述對象和數(shù)據(jù)庫之間映射的元數(shù)據(jù),將程序中的對象自動持久化到關(guān)系數(shù)據(jù)庫中。

為什么使用dbflow?

1、 速度

基于AnnotationProcessing(注解處理器),在編譯時生成代碼,運行時性能優(yōu)良,通過復用對象以及緩存機制,得到不錯的速度體驗。

2、 擴展性

數(shù)據(jù)表單映射到數(shù)據(jù)對象,通過該對象繼承Model類,一般的話繼承BaseModel類就可以,對類內(nèi)成員添加注解生成所需要的表單。

3、 查詢語句

如果你使用過greenDao等其他的庫的話,查詢語句都非常接近SQL語句。

4、 基于sqlite

不限制平臺,有sqlite的地方就可以使用dbflow。

5、 開源

源碼是個好東西,有能力的人可以看看。https://github.com/Raizlabs/DBFlow

怎么使用dbflow

配置環(huán)境

不管是想學習什么東西,環(huán)境就是個主要東西,那對于一個三方庫來說第一步就是導入類庫。

首先在主要的build.gradle中添加maven地址:

allprojects {
 repositories {
     maven { url "https://jitpack.io" } }
}

其次在基類module中添加依賴:

復制代碼 代碼如下:

def dbflow_version = "4.2.4" dependencies {     annotationProcessor "com.github.Raizlabs.DBFlow:dbflow-processor:${dbflow_version}" compile "com.github.Raizlabs.DBFlow:dbflow-core:${dbflow_version}" compile "com.github.Raizlabs.DBFlow:dbflow:${dbflow_version}" compile "com.github.Raizlabs.DBFlow:dbflow-rx2:${dbflow_version}" compile "com.github.Raizlabs.DBFlow:dbflow-sqlcipher:${dbflow_version}" }

如果需要添加kotlin的代碼的話查看上文的源碼地址下方有說明。

使用

在Application中添加init

FlowManager.*init*(this);

創(chuàng)建數(shù)據(jù)庫

@Database(name = DbFlowData.*DBNAME*,version = DbFlowData.*VERSION*) 
public class DbFlowData {
 public static final String *DBNAME*="DbFlowData";
 public static final int *VERSION*=1; 
}

使用注解Database,name數(shù)據(jù)庫名稱 version數(shù)據(jù)庫版本

創(chuàng)建表單

@Table(database = DbFlowData.class)
 public class DbFlowModel extends BaseModel { 
@PrimaryKey(autoincrement = true) public int id; 
@Column public String name;

 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; }

}

使用注解Table database從屬數(shù)據(jù)庫對象,表單屬性使用各類注解,PrimaryKey主鍵,Colum列。

注意:這里我們繼承的 BaseModel 是 DBFlow 給我們提供的,是可以不繼承的,差別僅僅增刪改查的操作上有所不同。

創(chuàng)建完后,點擊Build->make,會在..\build\generated\source\apt\debug下生成必要代碼。

插入:

創(chuàng)建一個表單對象,賦值完,調(diào)用save方法即可插入操作。

復制代碼 代碼如下:
DbFlowModel dbFlowModel = new DbFlowModel(); dbFlowModel.name = name; dbFlowModel.save();

刪除:

類似于sql語句的代碼進行操作

SQLite.*delete*()
 .from(DbFlowModel.class)
 .where(DbFlowModel_Table.*id*.eq(id), DbFlowModel_Table.*name*.eq(name))
 .execute();

查詢:

這個有很多復雜的查詢操作,想知道詳細的還是看官方文檔。

復制代碼 代碼如下:
List list = SQLite.*select*().from(DbFlowModel.class).queryList();

更新:

都是類似的。

SQLite.*update*(DbFlowModel.class)
 .set(DbFlowModel_Table.*name*.eq("PXXXX"))
 .where(DbFlowModel_Table.*name*.eq("P0000"))
 .execute();

注意:新建表單后,需要對數(shù)據(jù)庫的version進行升級,不然會報錯的。

這里主要簡單的介紹一下dbflow的基本使用,主要用作分享和記錄一些好用的東西,

源碼:https://github.com/xiaogoudandan/WilliamApp

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


新聞名稱:Androidbdflow數(shù)據(jù)庫神器的使用
轉(zhuǎn)載源于:http://weahome.cn/article/jdjsih.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部