greenDao基本使用步骤

greenDao基本使用步骤



  • 第一步:接入jar包
  1. app的build.gradle中

dependencies 的节点下添加依赖

compile 'org.greenrobot:greendao:3.2.2'
compile 'org.greenrobot:greendao-generator:3.2.2'
  1. 在project的build.gradle中

buildscript 下的 dependencies中添加

 classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2'

allprojects 下的 repositories 中添加

mavenCentral() // add repository
  1. 新建的AndroidLib库中

lib 的build.gradle 中最上面添加:

apply plugin: 'org.greenrobot.greendao'

在android节点下添加:greendao配置文件

greendao {
        schemaVersion 2
        daoPackage 'com.mrko.dao'
        targetGenDir 'src/main/java'
    }

dependencies 节点下添加:greenDao依赖

compile 'org.greenrobot:greendao:3.2.2'
compile 'org.greenrobot:greendao-generator:3.2.2'
  1. 将新建的AndroidLib库依赖到APP项目中、

  • 第二步:新建AndroidLib。实现封装Utils

只有建立完成之后才能去进行build.gradle配置(也就是第一步的3.4点)

  1. 新建一个module-->选择Android jar。
  2. 进行第一步中的序号3进行gradle的配置。
  3. 新建一个DBApplication。代码如下

DBApplication这继承的是app的Application
本身AndroidManifest.xml不做处理

package com.mrko;
import android.app.Application;
import com.mrko.dao.DaoMaster;
import com.mrko.dao.DaoSession;
import org.greenrobot.greendao.database.Database;

/**
 * Created by Mrko on 2017/9/19-10:16.
 * Email:mrko0630@163.com
 */

public class DBApplication extends Application {
    //定义数据库名称
    public static final String DB_NAME = "Stuent.db";
    private DaoSession session;
    //获取本地的一个实例
    private static DBApplication DBApplication;

    @Override
    public void onCreate() {
        super.onCreate();
        DBApplication = this;
        initDB();
    }

    /**
     * 初始化
     * 1.先获取DexOpenHelper的实例。新建一个数据库表
     * 2.获取dataBase的写入权限
     * 3.新建一个DaoMaster类。将dataBase交给其管理
     * 4.获取到Session的实例(session就是操作数据库的直接类)
     */
    public void initDB() {
        DaoMaster.DevOpenHelper devOpenHelper = new DaoMaster.DevOpenHelper(this, DB_NAME);
        Database database = devOpenHelper.getWritableDb();
        DaoMaster daoMaster = new DaoMaster(database);
        session = daoMaster.newSession();
    }

    public static DBApplication getAPPlication() {
        return DBApplication;
    }

    public synchronized DaoSession getDaoSession() {
        if (session == null) {
            initDB();
        }
        return session;
    }
}


  • 第三步:新建实体类、也就是数据库表中所需要字段。

Student 类。

  1. 开始新建时候代码如下:
package com.mrko.mydb;
import org.greenrobot.greendao.annotation.Entity;
import org.greenrobot.greendao.annotation.Id;
import org.greenrobot.greendao.annotation.Property;

/**
 * Created by Mrko on 2017/9/19-10:00.
 * Email:mrko0630@163.com
 */

@Entity
public class Student {
    //注意 是Long 不是long 
    @Id(autoincrement = true)
    private Long id;

    @Property(nameInDb = "name")
    private String name;

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

    
}

  1. 然后在Make project (点击小锤子)
  2. 新生成代码如下:并会在build.gradle中配置的地址(targetGenDir 'src/main/java')的目录下生成三个实体类(DaoMaster、DaoSession、StudentDao)(一般添加新的字段。可以把之前生成的三个实体类删除,重新生成)
package com.mrko.mydb;

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 Mrko on 2017/9/19-10:00.
 * Email:mrko0630@163.com
 */

@Entity
public class Student {
    //注意 是Long 不是long
    @Id(autoincrement = true)
    private Long id;

    @Property(nameInDb = "name")
    private String name;

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

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

    @Generated(hash = 1556870573)
    public Student() {
    }

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

    
    
}

  • 第四步:新建数据库工具类

    DBUtils 数据库统一管理实现封装

package com.mrko.helper;

import android.util.Log;

import com.mrko.DBApplication;
import com.mrko.dao.DaoSession;
import com.mrko.dao.StudentDao;
import com.mrko.mydb.Student;

import org.greenrobot.greendao.query.QueryBuilder;

import java.util.List;

import static android.content.ContentValues.TAG;

/**
 * Created by Mrko on 2017/9/19-10:35.
 * Email:mrko0630@163.com
 */

public class DBStudentUtils {
    private static DaoSession mDaoSession;
    private static StudentDao mStuentDao;
    private static DBStudentUtils instance = null;

    private DBStudentUtils() {

    }

    /**
     * 双重校验锁单例模式
     * 实例化Session和Dao类
     * @return
     */
    public static DBStudentUtils getInstance() {
        if (instance == null) {
            synchronized (DBStudentUtils.class) {
                if (instance == null) {
                    instance = new DBStudentUtils();
                }
                mDaoSession = DBApplication.getAPPlication().getDaoSession();
                mStuentDao = mDaoSession.getStudentDao();
            }
        }
        return instance;
    }

    public Student makeStudent(String name, int age) {
        Student student = null;
        if (student == null) {
            student = new Student();
            Log.e(TAG, "makeStudent: " + student.getId());
            student.setName(name);
            student.setAge(age);
            insertStudent(student);
        }
        return student;
    }

    public void insertStudent(Student student) {
        mStuentDao.insert(student);
    }

    public void updateStudent(Student student) {
        mStuentDao.update(student);
    }

    public void deleteStudent(Long id) {
        mStuentDao.deleteByKey(id);
    }

    public List<Student> queryStudent(int age) {
        QueryBuilder<Student> queryBuilder = mStuentDao.queryBuilder();
        queryBuilder.where(StudentDao.Properties.Age.gt(age));
        List<Student> queryStudents = queryBuilder.list();
        return queryStudents;
    }

}

  • 第五步:如何调用:
package com.mrko.testone.dao;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;

import com.mrko.helper.DBStudentUtils;
import com.mrko.mydb.Student;
import com.mrko.testone.R;
import com.socks.library.KLog;

import java.util.ArrayList;
import java.util.List;

import butterknife.BindView;
import butterknife.ButterKnife;
import butterknife.OnClick;
import butterknife.Unbinder;

public class DaoTestTwoActivity extends Activity {

    @BindView(R.id.et_name)
    EditText etName;
    @BindView(R.id.et_age)
    EditText etAge;
    @BindView(R.id.btn_save)
    Button btnSave;
    @BindView(R.id.btn_update)
    Button btnUpdate;
    @BindView(R.id.btn_delete)
    Button btnDelete;
    @BindView(R.id.btn_query)
    Button btnQuery;
    @BindView(R.id.listview)
    ListView listview;
    private Unbinder unbinder;
    private String mName;
    private int mAge;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_dao_test_two);
        unbinder = ButterKnife.bind(this);
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        unbinder.unbind();
    }

    @OnClick({R.id.btn_save, R.id.btn_update, R.id.btn_delete, R.id.btn_query})
    public void onViewClicked(View view) {
        mName = etName.getText().toString().trim();
        String temp = etAge.getText().toString().trim();
        mAge = Integer.parseInt(temp == null || temp.equals("") ? "0" : temp);
        switch (view.getId()) {
            case R.id.btn_save:
                DBStudentUtils.getInstance().makeStudent(mName, mAge);
                break;
            case R.id.btn_update:
                DBStudentUtils.getInstance().makeStudent(mName, mAge);
                break;
            case R.id.btn_delete:
                List<Student> queryStudent = DBStudentUtils.getInstance().queryStudent(mAge);
                List<Long> deleteStudents= new ArrayList<>();
                if (queryStudent != null) {
                    for (Student student : queryStudent) {
                        KLog.e("mrko--->",student.getId() + "--" + student.getAge() + "--" + student.getName());
                        deleteStudents.add(student.getId());
                    }
                    if (deleteStudents!=null){
                        for(Long id : deleteStudents) {
                            DBStudentUtils.getInstance().deleteStudent(id);
                            KLog.e("mrko--->","delete id-->"+id);
                        }
                    }

                }
                break;
            case R.id.btn_query:
                List<Student> queryStudents = DBStudentUtils.getInstance().queryStudent(mAge);
                if (queryStudents != null) {
                    for (Student student : queryStudents) {
                        KLog.e("mrko--->" + student.getId() + "--" + student.getAge() + "--" + student.getName());
                    }
                }
                break;
        }
    }
}

  • 第六步:注意事项:

DBApplication需要在app的AndroidManifest.xml中实现android:name.. 如果重写application,继承DBAapplication、


基本接入步骤如上、当然greenDao很多探究、这里只是入门操作、、班门弄斧而已、

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容