首先添加相应依赖等配置:
// In your root build.gradle file:
buildscript {
repositories {
jcenter()
mavenCentral() // add repository
}
dependencies {
classpath 'com.android.tools.build:gradle:2.3.0'
classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2' // add plugin
}
}
// In your app projects build.gradle file:
apply plugin: 'com.android.application'
apply plugin: 'org.greenrobot.greendao' // apply plugin
dependencies {
compile 'org.greenrobot:greendao:3.2.2' // add library
}
greendao {
schemaVersion 1
daoPackage 'com.ping.greendao.gen' //这里是根目录(自定义)
targetGenDir 'src/main/java'
}
类注解为@Entity id注解为@id实体类id一定要定义为Long类型
写好注解要在Build中 编译一下,编译后会自己生成一些代码,gen目录也会生成出来。
这里的几个注解含义:
- @Entity:将我们的java普通类变为一个能够被greenDAO识别的数据库类型的实体类;
- @nameInDb:在数据库中的名字,如不写则为实体中类名;
- @Id:选择一个long / Long属性作为实体ID。 在数据库方面,它是主键。 参数autoincrement是设置ID值自增;
- @NotNull:使该属性在数据库端成为“NOT NULL”列。 通常使用@NotNull标记原始类型(long,int,short,byte)是有意义的;
- @Transient:表明这个字段不会被写入数据库,只是作为一个普通的java类字段,用来临时存储数据的,不会被持久化。
简单封装一个DBUtils
public class DBUtils { private static volatile DBUtils instance; private final PersonDao dao; private DBUtils(Context context){ // 初始化数据库的一些配置 DaoMaster.DevOpenHelper helper = new DaoMaster.DevOpenHelper(context, "user", null); // 获取数据库操作对象 SQLiteDatabase db = helper.getWritableDatabase(); // 获取DaoMaster对象 DaoMaster daoMaster = new DaoMaster(db); // 获取DaoSession对象 DaoSession daoSession = daoMaster.newSession(); //获得操作对象 dao = daoSession.getPersonDao(); } public static DBUtils getInstance(Context context){ if(null==instance){ synchronized (DBUtils.class){ if(instance==null){ instance=new DBUtils(context); } } } return instance; } public PersonDao getDao(){ return dao; } }
配置完就可以使用了。