Android greendao配置及使用

Android greendao配置及使用

之前公司项目为工业软件,使用SQLite 自定义封装,可视化工具查看

优点:数据可视化,数据库可导出查看,操作稳定
缺点:增删改查麻烦,SQLite语言繁琐

听说greendao使用方便,在此学习一下配置和使用

优点:效率很高,插入和更新的速度是sqlite的2倍,加载实体的速度是ormlite的4.5倍。
缺点:学习成本较高。其中使用了一个java工程根据一些属性和规则去generate一些基础代码,类似于javaBean但会有一些规则,另外还有QueryBuilder、Dao等API,所以首先要明白整个过程,才能方便使用。没有ORMLite那样封装的完整,不过greenDao的官网上也提到了这一点,正是基于generator而不是反射,才使得其效率高的多。


现在开始配置
在 .src/main 目录下新建一个「java-gen」目录 
存放java类运行出的类
Android greendao配置及使用_第1张图片

                   名字是  java-gen
配置 Android 工程(app)的 build.gradle,如图分别添加  sourceSets  与 dependencies 。  Android greendao配置及使用_第2张图片      
Android greendao配置及使用_第3张图片

sourceSets {
    main {
        java.srcDirs = ['src/main/java', 'src/main/java-gen']
    }
}
compile 'de.greenrobot:greendao:1.3.7'

通过 File -> New -> New Module -> Java Library -> 填写相应的包名与类名 -> Finish.

Android greendao配置及使用_第4张图片



build.gradle里
 
   
dependencies {
compile fileTree( dir : 'libs' , include : [ '*.jar' ])
compile 'de.greenrobot:greendao-generator:1.3.1'
}

public class MyGreenDao {
    public static void main(String[] args) throws Exception {
        // 正如你所见的,你创建了一个用于添加实体(Entity)的模式(Schema)对象。
        // 两个参数分别代表:数据库版本号与自动生成代码的包路径。
        Schema schema = new Schema(1, "my.ly.greendao");
        // 当然,如果你愿意,你也可以分别指定生成的 Bean 与 DAO 类所在的目录,只要如下所示:
        // Schema schema = new Schema(1, "me.ly.bean");
        // schema.setDefaultJavaPackageDao("me.ly.dao");
        // 模式(Schema)同时也拥有两个默认的 flags,分别用来标示 entity 是否是 activie 以及是否使用 keep sections。
        // schema2.enableActiveEntitiesByDefault();
        // schema2.enableKeepSectionsByDefault();
        // 一旦你拥有了一个 Schema 对象后,你便可以使用它添加实体(Entities)了。
        addNote(schema);
        // 最后我们将使用 DAOGenerator 类的 generateAll() 方法自动生成代码,此处你需要根据自己的情况更改输出目录(既之前创建的 java-gen)。
        // 其实,输出目录的路径可以在 build.gradle 中设置,有兴趣的朋友可以自行搜索,这里就不再详解。
        new DaoGenerator().generateAll(schema, "C:/Users/ly/Downloads/ExerciseGreenDAO/app/src/main/java-gen");
    }

    /**
     * @param schema
     */
    private static void addNote(Schema schema) {
        // 一个实体(类)就关联到数据库中的一张表,此处表名为「Girl」(既类名)
        Entity note = schema.addEntity("Girl");
        // 你也可以重新给表命名
        // note.setTableName("Girls");
        // greenDAO 会自动根据实体类的属性值来创建表字段,并赋予默认值
        // 接下来你便可以设置表中的字段:
        // 与在 Java 中使用驼峰命名法不同,默认数据库中的命名是使用大写和下划线来分割单词的。
        // For example, a property called “creationDate” will become a database column “CREATION_DATE”.
        note.addStringProperty("iconUrl").notNull();
        note.addStringProperty("mediumUrl").notNull();
        note.addStringProperty("name").notNull();
        note.addIntProperty("height").notNull();
        note.addIntProperty("width").notNull();
    }
}

写好这个之后要运行这个java类 千万不要直接点 项目运行 那是不对的!!!!!!!!!!

Android greendao配置及使用_第5张图片

运行之后 run里是这样的 不是这样的就表示你的java类未生成

如果没问题了进行下一步

private void setupDatabase() {
    // 通过 DaoMaster 的内部类 DevOpenHelper,可以得到一个便利的 SQLiteOpenHelper 对象。
    // 可能你已经注意到了,你并不需要去编写「CREATE TABLE」这样的 SQL 语句,因为 greenDAO 已经帮你做了。
    // 注意:默认的 DaoMaster.DevOpenHelper 会在数据库升级时,删除所有的表,意味着这将导致数据的丢失。
    // 所以,在正式的项目中,你还应该做一层封装,来实现数据库的安全升级。
    helper = new DaoMaster.DevOpenHelper(this, "Girl", null);
    db = helper.getWritableDatabase();
    // 注意:该数据库连接属于 DaoMaster,所以多个 Session 指的是相同的数据库连接。
    daoMaster = new DaoMaster(db);
    daoSession = daoMaster.newSession();
}




new DaoGenerator().generateAll(schema, "C:/Users/ly/Downloads/ExerciseGreenDAO/app/src/main/java-gen");

记得把这个路径改成你们的

本项目下载地址
http://download.csdn.net/detail/qq_32368129/9522622

作者水平有限,不喜勿喷 ,谢谢

你可能感兴趣的:(greendao,android)