GreenDao使用

GreenDao的介绍及使用

GreenDao介绍

  1. 介绍
      greenDAO:Android ORM为您的SQLite数据库
    greenDAO Android ORMgreenDAO是一个开源的Android ORM,使SQLite数据库的开发再次有趣。它减轻开发人员处理低级数据库需求,同时节省开发时间。SQLite是一个令人敬畏的嵌入式关系数据库。不过,编写SQL和解析查询结果是相当乏味和耗时的任务。通过将Java对象映射到数据库表(称为ORM,“对象/关系映射”),greenDAO可以将它们从这些映射中释放出来。这样,您可以使用简单的面向对象的API来存储,更新,删除和查询Java对象。

  2. 特点

    • 最高性能(可能是Android最快的ORM); 我们的基准也是开源的
    • 易于使用的功能强大的API涵盖关系和联接
    • 最小的内存消耗
    • 依赖库文件小(<100KB),以保持您的构建时间较低,并避免65k方法限制
    • 数据库加密:greenDAO支持SQLCipher,以保护用户的数据安全
    • 强大的社区:超过5.000 GitHub明星表明有一个强大和积极的社区

GreenDao的使用

  1. 环境配置

    •  首先在project的build.gradle中添加依赖:
 dependencies {
     classpath 'org.greenrobot:greendao-gradle-plugin:3.2.0'
 }
  •  其次在app的build.gradle中添加插件:

apply plugin: ‘org.greenrobot.greendao’

    添加依赖:

dependencies {
    compile 'com.jakewharton:butterknife:8.5.1'
    annotationProcessor 'com.jakewharton:butterknife-compiler:8.5.1'
}

    添加版本:

android{
    greendao{
        schemaVersion 1
        targetGenDir 'src/main/java'
    }
}     

  至此,GreenDao的环境配置完成,同步一下Grandle就可以编写代码了。

  1. 代码的编写

    • 实体类的编写
      实体类是将数据库表通过GreenDao隐射成Java bean的一个类。示例代码如下:
package demo.android.greendaodemo;

import org.greenrobot.greendao.annotation.Entity;
import org.greenrobot.greendao.annotation.Id;
import org.greenrobot.greendao.annotation.Property;
import org.greenrobot.greendao.annotation.Generated;

/**
 * Created by android on 17-7-19.
 */

//必须加上@entity注解
@Entity
public class Test {

    //ID的注解也是必要的
    @Id
    private Long id;

    //@property对应着表中的字段
    @Property(nameInDb = "name")
    private String name;

    @Property(nameInDb = "age")
    private int age;

    @Generated(hash = 1255361573)
    public Test(Long id, String name, int age) {
        this.id = id;
        this.name = name;
        this.age = age;
    }

    @Generated(hash = 372557997)
    public Test() {
    }

    public Long getId() {
        return this.id;
    }

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

    public String getName() {
        return this.name;
    }

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

    public int getAge() {
        return this.age;
    }

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

在添上注解后,build一下项目补全实体类,同时还生成相对应的三个类,如TestDao、DaoMaster、DaoSession。

  • 接口的调用

在用GreenDao生成了对应的类后,就可以进行调用相关接口来对数据库进行增删改查了。示例代码如下:

package demo.android.greendaodemo;

import android.content.Context;

import java.util.List;


public class DbManager {

    private static final String dbName = "Test.db";
    private DaoMaster mDaoMaster;
    private DaoSession mSession;
    private TestDao testDao;

    public DbManager(Context context) {
        //创建数据库名
        DaoMaster.DevOpenHelper devOpenHelper = new DaoMaster.DevOpenHelper(context.getApplicationContext()
                , dbName, null);
        mDaoMaster = new DaoMaster(devOpenHelper.getWritableDb());
        mSession = mDaoMaster.newSession();
        testDao = mSession.getTestDao();
    }

    public void insert(String name, int age) {
        testDao.insert(new Test(null, name, age));
    }

    public Test queryRecentDate() {
        List<Test> list = testDao.queryBuilder().list();
        return list.size() == 0 ? null : list.get(list.size() - 1);
    }

    public List<Test> queryAll() {
        return testDao.queryBuilder().list();
    }

    public void delete() {
        testDao.deleteAll();
    }

    public void update(String name, int age) {
        List<Test> list1 = testDao.queryBuilder().where(TestDao.Properties.Name.eq(name)).list();
        List<Test> list2 = testDao.queryBuilder().where(TestDao.Properties.Age.eq(age)).list();

        if (list1.size() != 0) {
            list1.get(0).setAge(age);
            testDao.update(list1.get(0));
        } else if (list2.size() != 0) {
            list2.get(0).setName(name);
            testDao.update(list2.get(0));
        }


    }


}

此处相关接口方法仅仅是抛砖引玉,更多接口方法请直接看API。


  • demo地址

链接:http://pan.baidu.com/s/1jIkQuBs 密码:bnaa

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值