如要了解功能实现,请运行app程序查看控制台日志和源代码!
* 源代码 : AcmenXD/GreenDao3-Demo
* apk下载路径 : GreenDao3-Demo.apk
// 以下配置在app下的build.gradle配置即可
apply plugin: 'org.greenrobot.greendao'
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'org.greenrobot:greendao-gradle-plugin:3.2.1'
}
}
greendao {
/**
* 数据库版本号不能降低,会导致App无法安装
* 数据库字段发生变更或新增表时,更新这个版本号,运行Make Project
* 版本号历史:
* 1:2016年11月21日13:32:33 - > 创建初始库和表
*/
schemaVersion 1
daoPackage 'com.acmenxd.greendao3_demo.db.dao'//生成的dao文件存放路径
targetGenDir 'src/main/java'//自定义生成数据库文件的目录,可以将生成的文件放到我们的java目录中,而不是build中,这样就不用额外的设置资源目录了
}
compile 'org.greenrobot:greendao:3.2.0'
第一步
// Application中初始化数据库
DBManager.getInstance().init(this);
第二步
/**
* 创建表对应的实体类(注解为greenDAO提供,可参考https://github.com/greenrobot/greenDAO)
* 每个实体类对应一个数据库表,表名默认为全部大写的类名
*/
@Entity //将我们的java普通类变为一个能够被greenDAO识别的数据库类型的实体类
public class Student {
/**
* 注释解释:
*
* @NotNull : 表示该字段不可以为空
* @Unique : 表示该字段唯一
* @Index(unique = true) : 使普通属性改变成唯一索引属性
*/
@Id//通过这个注解标记的字段必须是Long类型的,这个字段在数据库中表示它就是主键,并且它默认就是自增的
private Long id;
@Property(nameInDb = "NAME")
private String name;
private int age;
private double score;
private Date date;
@Transient //表明这个字段不会被写入数据库,只是作为一个普通的java类字段,用来临时存储数据的,不会被持久化
private Date date2;
}
第三步
配置好build.gradle,运行Make Project,会自动生成部分代码和java文件(如运行失败,修复问题后,需再次运行)
第四步
创建StudentDB,为Student表添加 增删改查 函数
第五步
运行程序,会自动创建数据库表和字段
第一步
创建新的实体类 或 修改实体类(Student)
第二步
修改build.gradle中数据库的版本号,运行Make Project,会自动更改相关代码(如运行失败,修复问题后,需再次运行)
第三步
创建 MigratorHelper+数据库版本号 的类文件(此文件为数据库升级时,表结构的修改类),并在DBOpenHelper中确认MigratorHelper类的包名是否正确(因为这里用的反射)
第四步
/**
* 在MigratorHelper.onUpgrade函数中,更新数据库表结构
*/
public void onUpgrade(Database db) {
/**
* migrate()参数解释
* 参数一:数据库db实例
* 参数二:新增字段在更新数据库时回调, 设置其默认值, 如为null,字段会自动设置默认值(参考DefaultCallback类)
* 参数三:需要更新或新建表的Dao.class类(有增删字段或新增的表必须在这里配置)
*/
MigrationHelperUtil.getInstance().migrate(db, new DefaultCallback() {
@Override
public String onText(String tablename, String columnName) {
return null;
}
public Long onInteger(String tablename, String columnName) {
return null;
}
@Override
public Double onReal(String tablename, String columnName) {
return null;
}
@Override
public Boolean onBoolean(String tablename, String columnName) {
return null;
}
}, StudentDao.class, Student2Dao.class, Student3Dao.class);
}
第五步
运行程序,会自动更新数据库表和字段
gitHub : https://github.com/AcmenXD 如对您有帮助,欢迎点Star支持,谢谢~
技术博客 : http://blog.csdn.net/wxd_beijing