打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
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.在moudel的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里面初始化/** * Created by Ruomiz on 2017/4/19 0019 */public class AppManager extends Application{@Overridepublic void onCreate() {    super.onCreate();    FlowManager.init(this);}

}

2.在Manifest中添加

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

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

/** * Created by Ruomiz on 2017/4/19 0019 */@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中有数据库的基本操作。

 /** * Created by Ruomiz on 2017/4/19 0019 */@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,有相关深入将继续总结。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Android连接SQLServer详细教程(数据库 服务器 客户端)
三行代码实现 TabLayout+ViewPager 的 Tab 滑动效果,从封装到开源
2017技术圈年度大事件盘点
第09组 Alpha冲刺(1/4)
优秀!适用于移动开发人员的开源跨平台桌面调试平台——Flipper
Android中使用SQLiteOpenHelper管理SD卡中的数据库
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服