服务器之家

服务器之家 > 正文

Android bdflow数据库神器的使用

时间:2021-04-16 15:26     来源/作者:WilliamIT

今日观看别人源码的时候偶然间发现了一个很好用的数据库神器,在这里分享一下。

什么是dbflow?

dbflow是Android SQLite ORM的一个使用注解操控的工具库。简单说就是对sqlite数据库进行操作的一个java库。

ORM(Object-relational mapping),中文翻译为对象关系映射,是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据库中。

为什么使用dbflow?

1、 速度

基于AnnotationProcessing(注解处理器),在编译时生成代码,运行时性能优良,通过复用对象以及缓存机制,得到不错的速度体验。

2、 扩展性

数据表单映射到数据对象,通过该对象继承Model类,一般的话继承BaseModel类就可以,对类内成员添加注解生成所需要的表单。

3、 查询语句

如果你使用过greenDao等其他的库的话,查询语句都非常接近SQL语句。

4、 基于sqlite

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

5、 开源

源码是个好东西,有能力的人可以看看。https://github.com/Raizlabs/DBFlow

怎么使用dbflow

配置环境

不管是想学习什么东西,环境就是个主要东西,那对于一个三方库来说第一步就是导入类库。

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

?
1
2
3
4
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

?
1
FlowManager.*init*(this);

创建数据库

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

使用注解Database,name数据库名称 version数据库版本

创建表单

?
1
2
3
4
5
6
7
8
9
10
11
@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从属数据库对象,表单属性使用各类注解,PrimaryKey主键,Colum列。

注意:这里我们继承的 BaseModel 是 DBFlow 给我们提供的,是可以不继承的,差别仅仅增删改查的操作上有所不同。

创建完后,点击Build->make,会在..\build\generated\source\apt\debug下生成必要代码。

插入:

创建一个表单对象,赋值完,调用save方法即可插入操作。

 

复制代码 代码如下:
DbFlowModel dbFlowModel = new DbFlowModel(); dbFlowModel.name = name; dbFlowModel.save();

 

 

删除:

类似于sql语句的代码进行操作

?
1
2
3
4
SQLite.*delete*()
 .from(DbFlowModel.class)
 .where(DbFlowModel_Table.*id*.eq(id), DbFlowModel_Table.*name*.eq(name))
 .execute();

查询:

这个有很多复杂的查询操作,想知道详细的还是看官方文档。

 

复制代码 代码如下:
List<DbFlowModel> list = SQLite.*select*().from(DbFlowModel.class).queryList();

 

 

更新:

都是类似的。

?
1
2
3
4
SQLite.*update*(DbFlowModel.class)
 .set(DbFlowModel_Table.*name*.eq("PXXXX"))
 .where(DbFlowModel_Table.*name*.eq("P0000"))
 .execute();

注意:新建表单后,需要对数据库的version进行升级,不然会报错的。

这里主要简单的介绍一下dbflow的基本使用,主要用作分享和记录一些好用的东西,

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
返回顶部