在AndroidStudio中使用GreenDAO

GreenDAO是一个移动开发的ORM框架,是当前最火的一个数据库开源框架。本文介绍如何在Android Studio中引入GreenDAO。

1.配置工程

1)在./src/main下面创建一个与java同级的java-gen文件夹

2)在build.gradle中加入

sourceSets {
   
main {
        java.srcDirs = ['src/main/java', 'src/main/java-gen']
   
}
}

这句话是为了把java-gen文件夹下的java文件也归入到srcDir中,程序就是通过这个文件夹下的几个java里的函数来操作数据库。

3)在dependencies中加入

compile 'de.greenrobot:greendao:1.3.7'
结果如图:


2.下载示例程序

地址:示例程序

1)将这个工程里的MyDaoGenerator文件夹拷贝到与app文件夹同层的目录里。在setting.gradle中修改内容:

include':app',':MyDaoGenerator'

这是为了把MyDaoGenerator include到工程中。

2)Clean Project。此时MyDaoGenerator.java已经显示正确引入到工程中(文件右下角没有红色的标志)。

3)打开MyDaoGenerator的build.gradle文件,配置outputDir,路径就是存放自动生成的java的那个包的路径,如:

def outputDir = "../app/src/main/java-gen"

此时完成所有GreenDAO环境的配置。


3.创建DAO.java等文件

1)

打开MyDaoGenerator工程中的MyDaoGenerator.java:

public class MyDaoGenerator {

    public static void main(String args[]) throws Exception {
        // 正如你所见的,你创建了一个用于添加实体(Entity)的模式(Schema)对象。
        // 两个参数分别代表:数据库版本号与自动生成代码的包路径。
        Schema schema = new Schema( 1, "com.example.bean");

        //schema.setDefaultJavaPackageDao("com.example.dao");
        // DaoMaster.java、DaoSession.java、BeanDao.java会放到/java-gen/com/example/dao中

        // 上面这两个文件夹路径都可以自定义,也可以不设置

        initNote(schema); // 初始化表了

        new DaoGenerator().generateAll(schema, args[0]);// 自动创建(这里的args[0]就是调用刚才设定的目录)
    }
    private static void initNote(Schema schema){
        // 一个实体(类)就关联到数据库中的一张表,此处表名为「Note」(即类名)
        Entity note = schema.addEntity("Note");
        // 你也可以重新给表命名
        // note.setTableName("NODE");

        // greenDAO 会自动根据实体类的属性值来创建表字段,并赋予默认值
        // 接下来你便可以设置表中的字段:
        note.addIdProperty();
        note.addStringProperty("text").notNull();
        // 与在 Java 中使用驼峰命名法不同,默认数据库中的命名是使用大写和下划线来分割单词的。
        // For example, a property called “creationDate” will become a database column “CREATION_DATE”.
        note.addStringProperty("comment");
        note.addDateProperty("date");
    }

}

2)此时在AndroidStudio的Gradel面板中执行run任务:(如果显示nothing to show,点击这个刷新按钮)

可以在消息栏里看到:

此时在java-gen下面可以看到已经自动生成了4个java文件:

DaoMaster:一看名字就知道它是Dao中的最大的官了。它保存了sqlitedatebase对象以及操作DAO classes(注意:不是对象)。其提供了一些创建和删除table的静态方法,其内部类OpenHelperDevOpenHelper实现了SQLiteOpenHelper并创建数据库的框架。

DaoSession:会话层。操作具体的DAO对象(注意:是对象),比如各种getter方法。

XXXDao:实际生成的某某DAO类,通常对应具体的java类,比如NoteDao等。其有更多的权限和方法来操作数据库元素。

XXXEntity:持久的实体对象。通常代表了一个数据库row的标准java properties。


4.在Android程序中调用

1)在继承自Application中的java文件中取到DaoMaster对象:(官方推荐将取得DaoMaster对象的方法放到Application层这样避免多次创建生成Session对象,在Application实现得到DaoMaster和DaoSession的方法):

helper = new DaoMaster.DevOpenHelper(this, "Note", null);
db = helper.getWritableDatabase();
// 注意:该数据库连接属于 DaoMaster,所以多个 Session 指的是相同的数据库连接。
daoMaster = new DaoMaster(db);
daoSession = daoMaster.newSession();
2)在Activity中利用Dao进行插入,搜索,删除等操作:
Note note = new Note(null, noteText, comment, new Date());
getNoteDao().insert(note);

 

Query query = getNoteDao().queryBuilder()
        .where(NoteDao.Properties.Text.eq(noteText))
        .orderAsc(NoteDao.Properties.Date)
        .build();
// 查询结果以 List 返回
List notes = query.list();
ToastUtils.show(getApplicationContext(), "There have " + notes.size() + " records");

 

getNoteDao().deleteByKey(id);


注:生成的db文件可以root后用Root Explorer在data-data文件夹下找到对应的包名,在databases里看到。


最后附上整个程序:Example


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值