Room VS GreenDao

  • 实体 - 表 对应 主键 外键(一对一,一对多)
  • 获取Database
  • dao操作
  • 加密
  • 数据库升级
  • LiveData的支持

框架图

Room:

GreenDao:

实体 - 表

  • Room

1、创建一个实体ProductEntity.java 使用@Entity注解标注:@Entity可以指定表名tableName,添加索引,外键等。
2、如果不指定tableName,默认是用类名作为数据库的表名。
3、主键使用PrimaryKey注解,可以设置autoGenerate = true表示主键自增。
4、其他属性默认都会作为表中的字段,如果不想要该字段可以使用@Ignore注解,表示忽略此属性。
5、你可以指定对象之间的关联。虽然大多数ORM库允许entity对象相互引用,但是Room明确禁止了这种行为。
虽然不可以使用直接的关联,Room仍然允许你定义entity之间的外键(Foreign Key)约束。

@Entity(tableName = "products",
        indices = {@Index(value = {"id","name"},unique = true)})
public class ProductEntity implements Product{
    @PrimaryKey(autoGenerate = true)
    private Long id;
    private String name;
    private String description;
    private double price;
    @Ignore
    private String testField;
}
  • GreenDao

1、创建一个实体类ProductEntity.java,使用@Entity注解标注:@Entity可以指定表名nameInDb=“”,索引等
2、如果不指定nameInDb,默认使用类名作为表名。
3、主键使用@Id注解标注,可以设置autoincrement = true让主键自增,注意:这里主键类型必须是Long,因为只有id=null时自增才会生效。
4、其他属性默认都会作为表中的字段,如果不需要时使用Transient注解忽略此属性。
5、支持对象之间的关联(一对一,一对多等等)

@Entity
public class ProductEntity implements Product {

    @Id(autoincrement = true)
    private Long id;    //这个逼玩意必须是Long,因为在数据库中只有id=null时才会自增。
    private String name;
    private String description;
    private double price;
    @Transient //忽略此属性
    private String testColumn;
}

Database

Room:

1、使用Room时需要创建自己的AppDatabasele抽象类,并且继承自RoomDatabase。
2、使用@Database注解标注,其中可以指定entitys,将这个库中所有的表对应的实体放在entitys中,version字段可以指定数据库版本。
3、Dao对象需要开发者编写各entity对应的Dao接口,并用@Dao注解标注,接口中提供需要的方法声明。Room会自动生成对应的实现类,并实现所有的方法。

@Dao
public interface ProductDao {

    @Query("select * from products")
    List<ProductEntity> queryProducts();

    @Query("select * from products where id = :productId")
    ProductEntity getProductById(long productId);

    @Insert(onConflict = OnConflictStrategy.REPLACE)
    void insertAll(ProductEntity... entity);

    @Update(onConflict = OnConflictStrategy.REPLACE)
    void updateAll(ProductEntity... entity);

    @Delete
    void deleteAll(ProductEntity... entity);

}

4、在AppDatabase中提供对应实体的Dao的方法声明。这样就可以通过APPDatabase实例获取到指定的dao对应从而操作表了。
说明:Room会自动生成该类的实现类。使用时直接调用即可。代码如下:

@Database(entities = {ProductEntity.class, CommentEntity.class},version = 1)
@TypeConverters(DateConverter.class)
public abstract class AppDatabase extends RoomDatabase {
    public static String DATABASE_NAME = "room-sample-db";

    public abstract ProductDao productDao();

    public abstract CommentDao commentDao();
}

5、获取数据库实例

使用Room提供的静态方法创建数据库。代码如下:

appDatabase = Room.databaseBuilder(context.getApplicationContext(),
                AppDatabase.class,DATABASE_NAME)
                .addMigrations(MIGRATION_1_2)
                .build();

GreenDao

1、使用GreenDao时会自动生成DaoMaster,DaoSession,XXXEntityDao三个类。

DaoMaster
  • 是GreenDao的入口,也是greenDao顶级对象,对于一个指定的表单持有数据库对象(SQLite数据库)并且能够管理DAO类- 能够创建表和删除表
  • 其内部类OpenHelper 与DevOpenHelper是创建SQlite数据库的SQLiteOpenHelper的具体实现
DaoSession
  • 对于一个指定的表单可以管理所有的Dao 对象。
  • 也能够对实体类执行 insert ,load,update,refresh.delete操作。
  • DaoSession也能跟踪 identity scope:即session查询后的实体会存在缓存中,并给该实体生成一个flag来追踪该实体,下次再次查询时会直接从缓存中取出来而不是从数据库中取出来
Daos
  • 能够持久访问和查询实体类
  • 比起DaoSession有更多的持久化方法 count, loadAll,insertInt等等;

2、获取数据库实例

1)、首先需要获取SQLiteOpenHelper对象。可以通过DaoMaster中的DevOpenHelper来实例化,也可以自定义类实现DaoMaster中的OpenHelper.

SQLiteOpenHelper oh = new DaoMaster.DevOpenHelper(context,DB_NAME,null);

2)、获取DaoSession: 通过DaoMaster的newSession()获取。

mDatabase = oh.getWritableDb();
daoSession = new DaoMaster(mDatabase).newSession();

3)、获取Dao对象:通过DaoSession获取

daoSession.getProductEntityDao();

注:
1、Room将生成Dao的控制权交由开发者,开发者决定需要那些dao。这样可以避免将所有的Entity都生成对应的Dao。更加灵活可控,也可以减少代码量。
GreenDao的工作方式是你只需要给我一个Entity,它就会生成所有东西,使用时只需要取对应的对象去操作即可。灵活性不如Room。
2、GreenDao提供了DaoSession会话,缓存层。可以很大程度来提高查询效率。Room貌似没有这样的缓存。

操作Sql(增删改查)

insert,update,delete

Room:使用@Insert,@Update,@Delete注解,并且可以指定相应的策略(replace,rollback,fail等)
GreenDao:直接生成对应的方法。没有提供相应的策略。但是提供了执行sql的方法。

query

Room:使用@Query注解标注,直接传sql

GreenDao:以对象的方式操作。可以使用QueryBuilder类执行各种复杂的查询。

两者做法各有千秋,就看使用者的习惯。就我个人而言还更喜欢使用纯sql,可读性高。

加密

Room不支持SqlCipher加密,不过后续SqlCipher应该会提供针对Room的加密方式,这只是时间的问题。

GreenDao集成了SqlCipher加密。

数据库升级

Room

生成AppDatabase实例时可以通过addMigrations()添加对应的Migration来支持迁移操作。代码如下:

appDatabase = Room.databaseBuilder(context.getApplicationContext(),
                AppDatabase.class,DATABASE_NAME)
                .addMigrations(MIGRATION_1_2)
                .build();
                
private static Migration MIGRATION_1_2 = new Migration(1,2) {
        @Override
        public void migrate(SupportSQLiteDatabase database) {
            //// TODO: 2017/6/12
        }
    };

GreenDao

通过重写DaoMaster.OpenHelper类实现迁移操作:

public static class AppSQLiteOpenHelper extends DaoMaster.OpenHelper{

        public AppSQLiteOpenHelper(Context context, String name) {
            super(context, name);
        }

        public AppSQLiteOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory) {
            super(context, name, factory);
        }

        @Override
        public void onUpgrade(Database db, int oldVersion, int newVersion) {
            //数据库迁移操作
            MigrationHelper.getInstance().migrate(db,ProductEntityDao.class, CommentEntityDao.class);
        }
    }

Room添加对liveData的支持
GreenDao不支持LiveData,需要自己实现。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,165评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,503评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,295评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,589评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,439评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,342评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,749评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,397评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,700评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,740评论 2 313
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,523评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,364评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,755评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,024评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,297评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,721评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,918评论 2 336

推荐阅读更多精彩内容