DBFlow的初步使用

作者: Ruomiz | 来源:发表于2017-04-19 16:28 被阅读8076次

    前言

    最近刚好有点时间,就想重温一下 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,有相关深入将继续总结。

    相关文章

      网友评论

        本文标题:DBFlow的初步使用

        本文链接:https://www.haomeiwen.com/subject/jqrhzttx.html