DBFlow的初步使用

前言

最近刚好有点时间,就想重温一下 Android 数据库的相关知识。以前一直使用 GreenDao,感觉操作起来代码比较冗余。就准备研究一下另外一种框架 DBFlow。

DBFlow

偶然发现 DBFlow ORM 库,发现是采用注解和注解处理器的术,性能强大而稳定,关键是可以省略到大量冗余的数据库代码。

Github官方地址

DBFlow官方教程

DBFlow配置

1.在 project 的 build 里面 ​

repositories {
    mavenCentral()
    jcenter()
}
dependencies {
    classpath 'com.android.tools.build:gradle:2.2.2'
    classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
}
}

2.添加仓库托管地址

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

3.在 module 的 build.gradle 中添加

添加依赖
dependencies {
apt '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}"

// sql-cipher database encyrption (optional)
compile "com.github.Raizlabs.DBFlow:dbflow-sqlcipher:${dbflow_version}"
}

使用

1.新建一个类继承 application 在 onCreat 里面初始化

public class AppManager extends Application{

@Override
public void onCreate() {
    super.onCreate();
    FlowManager.init(this);
    }
}

2.在 Manifest 中添加

<application
    android:name=".AppManager"
    ....>

3.创建数据库自自己创建一个类,定义数据库的名称 、版本

@Database(name = DBFlowDataBase.NAME, version = DBFlowDataBase.VERSION)
public class DBFlowDataBase {
    //数据库名称
    public static final String NAME = "RuomizDataBase";
    //数据库版本
    public static final int VERSION = 1;
}

4.创建一个 model 文件 继承 BaseModel,继承 BaseModel 中有数据库的基本操作。

@Table(database = DBFlowDataBase.class) //上面自己创建的类(定义表的名称 版本)
public class DBFlowModel extends BaseModel{

    @PrimaryKey(autoincrement = true) //主键  //autoincrement 开启自增
    public int id;
    
    @Column               //表示一栏 一列
    public  String name; //自己需要存储的字段 
    
    @Column
    public int age;
    
    @Column
    public String address;
    
    @Column
    public int phone;
}

5.写完数据库对象以后 build——make project 然后在 app /build / generated / source / apt / debug / packagename /... 下面生成一些文件如下图:


6 数据库的增删改查

    DBFlowModel dbFlowModel = new DBFlowMod();
    dbFlowModel.name = "Ruomiz";
    dbFlowModel.address = "Wuhan";
    dbFlowModel.age = "100";
    dbFlowModel.phone = "13333333333";
    dbFlowModel.save(); 

    //dbFlowModel.update(); 
    //dbFlowModel.delete(); 
    //dbFlowModel.insert(); 

7.查询

//根据 name 单个查询
DBFlowModel dbFlowModel = new Select()
.from(DBFlowModel.class)
.where(DBFlowModel_Table.name.is("Ruomiz"))
.querySingle();

//单个查询
DBFlowDataBase dbFlowDataBase = new Select()
.from(DBFlowDataBase.class)
.querySingle();

//返回所有结果
List<DBFlowDataBase> dbFlowDataBases = new Select()
.from(DBFlowDataBase.class)
.queryList();

8.到此就已经成功实现 DBFlow 的简单操作了。版本更新暂时还没有去了解,感兴趣的可以去官方教程查看(上面贴了链接),以后相关项目将会使用 DBFlow,有相关深入将继续总结。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,600评论 25 709
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,170评论 6 342
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,183评论 19 139
  • □/莫晓烟雨 清唱的公众号关注了一段时间了,两个很有事业心的女人林特特和艾小羊,一起管理的公众号,总是给我很多鼓励...
    莫晓烟雨阅读 4,073评论 2 3
  • 我有一个微信群,里面是我大学里最要好的几个闺蜜,天天都在有一搭没一搭地刷新着近况。很多时候都是刷刷着刷着,人...
    罐子小姐阅读 3,599评论 0 0

友情链接更多精彩内容