前言
下图是豌豆荚的某一个时间段的top500应用的分析。我们重点关注数据库部分,排在第一的是GreenDao,有什么优势也不用多说了,关键是怎么用起来是吧?
优势可以忽略,但是特性还是必须得说明一下:将对象映射到SQLite数据库,也就是说操作数据库只需要直接java对象即可,对于我这种半路出家的菜鸡简直是福音啊有木有,为什么?因为我不会数据库语法。。。/手动抠鼻。
另外,greenDao3.0和之前区别还是蛮大的,采用注解的方式通过编译方式生成Java数据对象和DAO对象,配置方式比以前2.x简易多了啊,所以使用3.0以前的朋友可能要换以下。
来啊,开始啊!
上代码! Demo
配置和使用
1.module的build.gradle添加:
apply plugin: 'org.greenrobot.greendao'//添加
2.module的build.gradle依赖添加:
compile'org.greenrobot:greendao:3.0.1' compile'org.greenrobot:greendao-generator:3.0.0'
3.module的build.gradle根级别下配置:
greendao { schemaVersion 1 //数据库版本号 daoPackage 'com.paradoxie.demo.dao' //生成的dao路径 targetGenDir 'src/main/java' //数据库文件的目录 }
4.在project的在build.gradle中配置:
dependencies { classpath 'com.android.tools.build:gradle:2.2.1' classpath 'org.greenrobot:greendao-gradle-plugin:3.0.0'//添加 }
5.编写java实体类,注意注解:
@Entity public class Advert { @Id private Long id;//主键id,必须Long型 private String classify;//广告类型 private String times;//广告次数 private String time;//广告时长
更多注解类型不在此列出,写完以上实体类属性后,编译,编译,编译,自动生成get、set内容以及第三步中配置的com.paradoxie.demo.dao目录下三个文件,就是这个:
6.编写MyOpenHelper,升级数据库使用,初步使用可以忽略:
7.编写核心类DbCore,构造方法略过,主要是两个静态方法:
public static DaoMaster getDaoMaster() { if (daoMaster == null) { //自定义辅助类;DevOpenHelper 会在数据库升级时,删除所有的表,意味着这将导致数据的丢失,此处使用OpenHelper。 DaoMaster.OpenHelper helper = new MyOpenHelper(mContext, DB_NAME); daoMaster = new DaoMaster(helper.getWritableDatabase()); } return daoMaster; } public static DaoSession getDaoSession() { if (daoSession == null) { if (daoMaster == null) { daoMaster = getDaoMaster(); } daoSession = daoMaster.newSession(); } return daoSession; }
8.在自定义MyApplication中初始化:
@Override public void onCreate() { super.onCreate(); //初始化数据库 DbCore.init(this); }
9.实例化mAdvertDao后,用其操作实体bean对象,例如:
mAdvertDao.insert(T entity);//增 mAdvertDao.delete(T entity);//删,也可deleteByKey(K key) mAdvertDao.update(T entity);//改 mAdvertDao.load(K key);//查
以上操作都有其他操作方法,可以跟进源码查看。
最后
以上配置和使用的简单说明,下面demo中有两个activity,来看数据库的不用管第二个哈。
如有帮助,不胜荣幸。