学习/参考地址:
GreenDao3.0数据库的简单使用
GreenDAO数据库升级
dependencies {
classpath 'com.android.tools.build:gradle:3.2.1'
classpath 'org.greenrobot:greendao-gradle-plugin:3.2.1'// add plugin
}
allprojects {
repositories {
jcenter()
mavenCentral() //添加存储库,注意添加的位置
}
}
apply plugin: 'com.android.application'
apply plugin: 'org.greenrobot.greendao' // apply plugin
dependencies {
implementation 'org.greenrobot:greendao:3.2.2' // add library
}
greendao {
schemaVersion 1
daoPackage 'com.anye.greendao.gen'
targetGenDir 'src/main/java'
}
@Entity
public class Student {
@Id
private Long id;
private String name;//姓名
private Long age;//年龄
private int classes;//班级
}
创建完成后,点击Make Project ,greendao会帮我们自动生成数据库表
创建数据库表需要注释:
@Entity 标识实体类,GreenDao会映射成sqlite中的一个表
@Id 标识主键
@Transient 标识该属性将不会映射到表中,也就是没有这列,不存储在数据库中
@Property 用于设置属性在数据库中的列名(默认不写就是保持一致)
@NotNull 非空
@Unique 唯一约束
@ToMany 一对多
@OrderBy 排序
我们通常会使用以上注释,更多注释,大家可以查看:GreenDao注释帮助文档。
public class APPAplication extends Application {
private static final String DBNAME = "person_db";
private static DaoSession mDaoSession;
@Override
public void onCreate() {
super.onCreate();
initGreenDao();
}
public void initGreenDao() {
DaoMaster.DevOpenHelper openHelper = new DaoMaster.DevOpenHelper(this,DBNAME){
@Override
public void onUpgrade(Database db, int oldVersion, int newVersion) {
/* 数据库升级时使用 */
int currentVersion = upgradeDB(db, oldVersion, newVersion);
if (currentVersion != newVersion) {
super.onUpgrade(db, oldVersion, newVersion);
}
}
};
Database writableDb = openHelper.getWritableDb();
DaoMaster daoMaster = new DaoMaster(writableDb);
mDaoSession = daoMaster.newSession();
}
public static DaoSession getDaoSession() {
return mDaoSession;
}
StudentDao mUserDao
private HistoryBeanDao getUserDao() {
if (mUserDao == null) {
mUserDao = APPAplication.getDaoSession().getStudentDao();
}
return mUserDao;
}
getUserDao().insert(user);
mStudentDao.delete(studen
mStudentDao.update(student);
// 按年龄排序分页查询
List<Student> users = getUserDao()
.queryBuilder()
.orderDesc(HistoryBeanDao.Properties.Age)
.offset(2*20)
.limit(15)
.list();
在Student中加入Address 属性
1)将Student 实体类中 带有@Generated(hash = xx)样式的构造方法删除
@Generated(hash = 36359539)
public Student(Long id, String name, Long age, int classes) {
this.id = id;
this.name = name;
this.age = age;
this.classes = classes;
}
@Generated(hash = 1556870573)
public Student() {
}
2)增加属性并添加Set,get方法
private String address;//地址
3) 重新 Make Project 生成新的带有@Generated的构造方法
4)找到自定义路径中的 StudentDao文件
/** Creates the underlying database table. */
public static void createTable(Database db, boolean ifNotExists) {
String constraint = ifNotExists? "IF NOT EXISTS ": "";
db.execSQL("CREATE TABLE " + constraint + "\"STUDENT\" (" + //
"\"_id\" INTEGER PRIMARY KEY ," + // 0: id
"\"NAME\" TEXT," + // 1: name
"\"AGE\" INTEGER," + // 2: age
"\"ADDRESS\" TEXT," + // 3: address
"\"CLASSES\" INTEGER NOT NULL );"); // 4: classes
}
5)在Application中的onUpgrade方法中判断数据库版本号 并 更新内容
找出 StudentDao文件中的 表名( STUDENT ) 列 名(ADDRESS)参数类型(TEXT)
if (oldVersion == 1) {
db.execSQL("ALTER TABLE " + "\"STUDENT\""
+ " ADD COLUMN \"ADDRESS\" TEXT");
currentVersion++;
}
if (oldVersion == 2) {
/** 适配数据库跳版本更新*/
currentVersion++;
}
6) 更新数据库版本号
greendao {
schemaVersion 2
daoPackage 'com.anye.greendao.gen'
targetGenDir 'src/main/java'
}
7) 完成
1)创建新的数据库表 并 Make Project
2)在Application中的onUpgrade方法中判断数据库版本号 、更新内容
if (oldVersion == 1) {
// 增加People表
PeopleBeanDao.createTable(db, true);
currentVersion++;
}
3) 更新数据库版本号
样例: (接 2.2、创建数据库中的upgradeDB() 方法)
public int upgradeDB(Database db, int oldVersion, int newVersion) {
int currentVersion = 0;
if (oldVersion == 1) {
// 增加People表
PeopleBeanDao.createTable(db, true);
currentVersion++;
}
if (oldVersion == 2) {
// 在表 STUDENT 中 添加 ADDRESS 属性
db.execSQL("ALTER TABLE " + "\"STUDENT\""
+ " ADD COLUMN \"ADDRESS\" TEXT");
currentVersion++;
}
if (oldVersion == 3) {
// 在表 STUDENT 中 添加 SEX 属性
db.execSQL("ALTER TABLE " + "\"STUDENT\""
+ " ADD COLUMN \"SEX\" TEXT");
currentVersion++;
}
return currentVersion;
}