程序员Android开发经验谈

GreenDao实操案例

2017-08-24  本文已影响0人  classliu

GreenDao实操案例

GreenDao实际项目使用


一.构建项目(已有的请开车到下面👇)

// 添加依赖到主项目gradle

compile'org.greenrobot:greendao:3.2.0'

compile 'com.facebook.stetho:stetho:1.3.1'

初始化 stetho 在Applcation中进行初始化的操作
Stetho.initializeWithDefaults(this)

二.自动生成所有的对象

greendao-generato 是一个 javalib moudle
右键run ~

`

public static void main(String[] args) throws Exception {
    Schema schema = new Schema(2, "com.classliu.greendao.db.bean"); //bean对象的路劲
    schema.setDefaultJavaPackageDao("com.classliu.greendao.db.dao"); //dao对象路径
    addTest(schema);
    addTest2(schema);
    addTest3(schema);
    addTest4(schema);
    addTest5(schema);

    //H:\demo\GreenDao\app\src
    //H:\demo\GreenDao\app\src\main\java-gen
    new DaoGenerator().generateAll(schema, "\\H:\\demo\\GreenDao\\app\\src\\main\\java-gen");
}



//生成bean对象
private static void addTest(Schema schema) {
    Entity testData = schema.addEntity("TestData"); //
    testData.addIdProperty().primaryKey().autoincrement();//primaryKey
    testData.addStringProperty("reader"); //reader 是 string 类型
    testData.addLongProperty("testLong"); //testLong 是 long 类型
    testData.addDateProperty("testDate");//testDate 是long 类型
    testData.addIntProperty("testInt");// testInt 是int 类型
    testData.addBooleanProperty("testBoolean"); //testBoolean 是布尔类型
    testData.addIntProperty("creatId"); 
}
private static void addTest2(Schema schema) {
    Entity testData = schema.addEntity("TestData2");
    testData.addIdProperty().primaryKey().autoincrement();
    testData.addStringProperty("testString");
    testData.addLongProperty("testLong");
    testData.addDateProperty("testDate");
    testData.addIntProperty("testInt");
    testData.addBooleanProperty("testBoolean");
}
private static void addTest3(Schema schema) {
    Entity testData = schema.addEntity("TestData3");
    testData.addIdProperty().primaryKey().autoincrement();
    testData.addStringProperty("testString");
    testData.addLongProperty("testLong");
    testData.addDateProperty("testDate");
    testData.addIntProperty("testInt");
    testData.addBooleanProperty("testBoolean");
}

private static void addTest4( Schema schema) {
    Entity testData = schema.addEntity("TestData4");
    testData.addIdProperty().primaryKey().autoincrement();
    testData.addStringProperty("reader");
    testData.addStringProperty("readerString");
    testData.addIntProperty("testInt");
    testData.addBooleanProperty("testBoolean");
}


private static void addTest5(Schema schema) {
    Entity testData = schema.addEntity("TestData5");
    testData.addIdProperty().primaryKey().autoincrement();
    testData.addStringProperty("testString");
    testData.addLongProperty("testLong");
    testData.addDateProperty("testDate");
    testData.addIntProperty("testInt");
    testData.addBooleanProperty("testBoolean");
}

`

三.数据库升级(数据迁移)

MySQLiteOpenHelper extends DaoMaster.OpenHelper 重写DaoMaster.OpenHelper
在onUpgrade方法中写出符合项目需求的升级操作,因为项目各异所有工具类的使用需要根据自身的要求量身需改。

四.结合标准MVP结构

五.总结

经实际测试:

感谢:如果喜欢本文加个收藏关注, Github star一下 Orz

上一篇 下一篇

猜你喜欢

热点阅读