浅谈Android数据库DBFlow

简介: 一、项目配置  1、根目录下的build.gradle 中添加 maven { url "https://www.jitpack.io" }  如下:  classpath 'com.

 

一、项目配置

  1、根目录下的build.gradle 中添加

        maven { url "https://www.jitpack.io" }

  如下:

  

classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'

     如下:

  

 

  2、app目录下的build.gradle 中添加

apply plugin: 'com.neenbedankt.android-apt'
def dbflow_version = "4.0.2"

  依赖:

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

 

  3、创建自己的Application

public class XApplication extends Application{
    @Override
    public void onCreate() {
        super.onCreate();
        FlowManager.init(this);
    }
}

    清单文件配置:

 

二、使用

  1、创建一个数据库类

/**
* @author xqx
* @email djlxqx@163.com
* blog:http://www.cnblogs.com/xqxacm/
* createAt 2017/11/22
* description: 数据库类
*/

@Database(name = SchoolDatabase.Name , version = SchoolDatabase.VERSION)
public class SchoolDatabase {
    static final String Name = "SchoolDB"; //数据库名
    static final int VERSION = 1;          //数据库版本号
}

 

  2、创建一个表类

/**
* @author xqx
* @email djlxqx@163.com
* blog:http://www.cnblogs.com/xqxacm/
* createAt 2017/11/22
* description: 学生表  属于SchoolDatabase数据库的
*/

@Table(database = SchoolDatabase.class)
public class Student extends BaseModel{
    //主键 一个表必须有至少一个主键
    // (autoincrement = true) 表示该字段是自增的,可以不设置 ,默认false
    @PrimaryKey(autoincrement = true)
    long id ;

    // 名字
    @Column
    String name;

    // 年龄
    @Column
    int age;


    //---------------------以下为可有可无的---------------//
  
  //注意 一定要有一个无参的构造方法
  public Student() {
  }
    /**
     * 构造方法 看情况添加 可不加
     * @param name
     * @param age
     */
    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }

    //Getter 和 Setter 方法,自己添加、可有可无
    public long getId() {
        return id;
    }

    public void setId(long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}

 

  3、增删改查

        Student student = new Student();
        student.setName("XQX");
        student.setAge(18);
        student.save();   //保存

        student.update(); // 更改
        student.delete();  //删除
        student.insert();  // 添加

   查询:

   /**
     * 查询年龄为100的学生记录
     * @param age
     * @return
     */
    public Student findSingleStudent(int age){
        Student student = SQLite.select().from(Student.class).where(Student_Table.age.is(100)).querySingle();
        return student;
    }

    public List getAllStudents(){
        List<Student> students = SQLite.select().from(Student.class).queryList();
        return students;
    }

  

  测试:

    for (int i = 0; i < 10; i++) {
            addStudent("学生:"+i , i);
        }

        List<Student> students = SQLite.select().from(Student.class).queryList();

        for (int i = 0; i < 10; i++) {
            Log.i("xqxinfo","学生表中的所有记录:"+students.get(i).toString());
        }

  结果:

    

  注意:如果一个表中的对象没有的话,save等同于insert都是添加记录 

     如果这个对象在表中存在,save即更新,不是添加

   

  官方介绍

相关文章
|
10月前
|
网络协议 关系型数据库 MySQL
如何实现无公网ip远程访问本地安卓Termux部署的MySQL数据库【内网穿透】
如何实现无公网ip远程访问本地安卓Termux部署的MySQL数据库【内网穿透】
|
9月前
|
数据库 Android开发 数据安全/隐私保护
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
317 2
|
9月前
|
SQL 存储 数据库
48. 【Android教程】数据库:SQLite 的使用
48. 【Android教程】数据库:SQLite 的使用
165 1
|
9月前
|
存储 缓存 数据库
Android之SQLite数据库使用详解
Android之SQLite数据库使用详解
|
10月前
|
数据库 Android开发
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
|
9月前
|
存储 数据库 Android开发
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
263 0
|
10月前
|
存储 SQL 数据库
【Android 从入门到出门】第六章:使用Room数据库并测试
【Android 从入门到出门】第六章:使用Room数据库并测试
133 4
|
10月前
|
网络协议 关系型数据库 MySQL
安卓手机termux上安装MariaDB数据库并实现公网环境下的远程连接
安卓手机termux上安装MariaDB数据库并实现公网环境下的远程连接
332 0
|
10月前
|
SQL 存储 数据库
Android数据库框架该如何选?
Android数据库框架该如何选?
346 0
|
SQL 存储 数据库
Android数 据库框架该如何选?
大家在 Android 上做数据持久化经常会用到数据库。 本文就这些数据库框架做一个横向对比,供大家在技术选型时做个参考。
378 0
Android数 据库框架该如何选?

热门文章

最新文章

  • 1
    【03】微信支付商户申请下户到配置完整流程-微信开放平台创建APP应用-填写上传基础资料-生成安卓证书-获取Apk签名-申请+配置完整流程-优雅草卓伊凡
    56
  • 2
    android FragmentManager 删除所有Fragment 重建
    25
  • 3
    Android实战经验之Kotlin中快速实现MVI架构
    39
  • 4
    即时通讯安全篇(一):正确地理解和使用Android端加密算法
    40
  • 5
    escrcpy:【技术党必看】Android开发,Escrcpy 让你无线投屏新体验!图形界面掌控 Android,30-120fps 超流畅!🔥
    44
  • 6
    【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
    155
  • 7
    Cellebrite UFED 4PC 7.71 (Windows) - Android 和 iOS 移动设备取证软件
    52
  • 8
    【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    67
  • 9
    Android历史版本与APK文件结构
    169
  • 10
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    54