Android greenDao的简单配置和使用

最近自学做东西的时候用到了一个收藏的功能,然后我想把东西存放到SQLite当中,然而自己传值的时候都是用到的实体类,所以存起来也比较麻烦,所以从网上找到一个greenDao的开源框架非常火,不仅效率高,而且内存也占用的小,非常方便。

这里我就简单介绍一下如何配置,至于其他的增、删、改、查了,网上都很多,需要用到的小伙伴们自己去查吧!!

首先我们得明白,greenDao是一个Java代码模版的快速生成器,里面封装好了我们实体类的各种操作。所以

1、我们要用eclipse或者Myeclipse建一个Java工程,我们需要在我们的工程下建立一个lib目录用于放我们的两个包(没有的小伙伴可以去网上下载)

Android greenDao的简单配置和使用

2、右键我们的工程,在弹出的菜单中选择Properties,将我们的两个jar包 加入到我们的工程中

Android greenDao的简单配置和使用

3、操作完成后,我们就可以编写代码了,建立一个类,在里面写下如下代码

package com.fanlei.greenDao;
import java.io.IOException; import de.greenrobot.daogenerator.DaoGenerator;
import de.greenrobot.daogenerator.Entity;
import de.greenrobot.daogenerator.Schema; public class ExampleDaoGenerator { public static void main(String[] args) throws IOException, Exception { Schema schema = new Schema(1, "de.greenrobot.daoexample"); addNote(schema); new DaoGenerator().generateAll(schema, "E:\\DaoExample\\src-gen"); } private static void addNote(Schema schema) { Entity news = schema.addEntity("News");
news.addStringProperty("author");
news.addStringProperty("content");
news.addStringProperty("id");
news.addStringProperty("img");
news.addStringProperty("pagetag");
news.addStringProperty("time");
news.addStringProperty("title");
}
}

首先

Schema schema = new Schema(1, "de.greenrobot.daoexample");  是必须要有的,这个视需要建立实体类要用到的,

两个参数   第一个是一个 版本,也就是说我们的SQLite数据库版本,后期如果需要数据库升级,就需要这个参数.

第二个是一个 路径,也就是你运行完这段代码后,生成的 .java 文件放在的地方.

方法addNote() 是添加实体类用的,你希望生成的实体类里面都有什么属性,这个需要自己去加入,属性的类型也很全面

Entity news = schema.addEntity("News");

会生成一个 News.java文件和NewsDao.java文件,NewsDao.java文件里面封装好了对数据库的操作

new DaoGenerator().generateAll(schema, "E:\\DaoExample\\src-gen");

第二个参数是你希望生成的文件存放在哪里.这个路径需要使用者事先去建好,否则会报异常.

最后生成的文件除了两个必要的.java文件,还有就是 你的实体类和实体类的Dao.

Android greenDao的简单配置和使用

4、最好将这几个.java文件考到你的android工程里面就可以使用了,android里面也需要一个jar包去支持,别忘了导入进去。(没有得网上可以下载)

Android greenDao的简单配置和使用

5、为了防止我们总是去创建session,官方推荐我们将session的生成放到application中,然后我们可以用get方法去获得

 public class MyApplication extends Application {

     private DaoMaster.DevOpenHelper helper;
private SQLiteDatabase db;
private DaoMaster daoMaster;
private DaoSession daoSession; @Override
public void onCreate() { helper = new DaoMaster.DevOpenHelper(this,"News_info-db",null);
db = helper.getWritableDatabase();
daoMaster = new DaoMaster(db);
daoSession = daoMaster.newSession();
}
}

6、插入操作也很简单

private News news;
private NewsDao newsDao; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_news_info);
getSupportActionBar().hide(); newsDao = MyApplication.getMyApplocation().getDaoSession().getNewsDao(); //拿到这么个工具dao newsDao.insert(news); //插入到数据库 }

若是第一次插入,则会创建一个表 表名就是类名,字段名就是属性名,这个表就是专门放News实体类的

7、其他操作请自行搜索,或者看官方文档

上一篇:poj 2253 Frogger【最小生成树变形】【kruskal】


下一篇:LeetCode算法题-Jewels and Stones(Java实现)