前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >浅谈Android数据库DBFlow

浅谈Android数据库DBFlow

作者头像
听着music睡
发布2018-05-18 16:07:39
6390
发布2018-05-18 16:07:39
举报
文章被收录于专栏:Android干货

一、项目配置

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

代码语言:javascript
复制
        maven { url "https://www.jitpack.io" }

  如下:

代码语言:javascript
复制
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'

     如下:

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

代码语言:javascript
复制
apply plugin: 'com.neenbedankt.android-apt'

依赖:

代码语言:javascript
复制
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

代码语言:javascript
复制
public class XApplication extends Application{
    @Override
    public void onCreate() {
        super.onCreate();
        FlowManager.init(this);
    }
}

清单文件配置:

二、使用

  1、创建一个数据库类

代码语言:javascript
复制
/**
* @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、创建一个表类

代码语言:javascript
复制
/**
* @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;


    //---------------------以下为可有可无的---------------//
  
  //注意 一定要有一个无参的构造方法

  3、增删改查

代码语言:javascript
复制
        Student student = new Student();
        student.setName("XQX");
        student.setAge(18);
        student.save();   //保存

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

  查询:

代码语言:javascript
复制
   /**
     * 查询年龄为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;
    }

  测试:

代码语言:javascript
复制
    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即更新,不是添加

官方介绍

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-11-22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档