最近自学做东西的时候用到了一个收藏的功能,然后我想把东西存放到SQLite当中,然而自己传值的时候都是用到的实体类,所以存起来也比较麻烦,所以从网上找到一个greenDao的开源框架非常火,不仅效率高,而且内存也占用的小,非常方便。
这里我就简单介绍一下如何配置,至于其他的增、删、改、查了,网上都很多,需要用到的小伙伴们自己去查吧!!
首先我们得明白,greenDao是一个Java代码模版的快速生成器,里面封装好了我们实体类的各种操作。所以
1、我们要用eclipse或者Myeclipse建一个Java工程,我们需要在我们的工程下建立一个lib目录用于放我们的两个包(没有的小伙伴可以去网上下载)
2、右键我们的工程,在弹出的菜单中选择Properties,将我们的两个jar包 加入到我们的工程中
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.
4、最好将这几个.java文件考到你的android工程里面就可以使用了,android里面也需要一个jar包去支持,别忘了导入进去。(没有得网上可以下载)
5、为了防止我们总是去创建session,官方推荐我们将session的生成放到application中,然后我们可以用get方法去获得
1 public class MyApplication extends Application { 2 3 private DaoMaster.DevOpenHelper helper; 4 private SQLiteDatabase db; 5 private DaoMaster daoMaster; 6 private DaoSession daoSession; 7 8 @Override 9 public void onCreate() { 10 11 12 helper = new DaoMaster.DevOpenHelper(this,"News_info-db",null); 13 db = helper.getWritableDatabase(); 14 daoMaster = new DaoMaster(db); 15 daoSession = daoMaster.newSession(); 16 } 17 }
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、其他操作请自行搜索,或者看官方文档