Android数据库框架GreenDao&Realm实战分析

标签: 数据库 greendao realm sqllite ormlite
8423人阅读 评论(10) 收藏 举报
分类:

Android开发的童鞋应该都知道,使用官方的SQLite数据库,可以满足我们大部分增删改查的需求,然而随着Android技术的逐步成长,你会慢慢发现SQLite越来越不能满足我们的需求。总结为以下主要几点:

  • 1、创表,增删改查需要些大量代码,开发效率极低。
  • 2、需大量封装,测试繁琐。
  • 3、效率极低(当你使用了GreenDao||Realm你会发现它完全不能接受)。
  • 4、加密等操作需手动处理。

正因为SQLite的繁琐使用,Andorid也会随着JAVA 的脚步出现大量的ORM框架,类似于JAVA Web的Hibernate。

目前流行的Andorid数据库框架

下面先列出目前流行的常见ORM框架:ORMLite、Afinal、ActiveAndroid、SugarORM、GreenDao、Realm
下面给出他们对应的仓库地址,从地址热度、star、更新时间,你也基本能判断出他们目前的流行程度与使用人数。
ORMLite:https://github.com/j256/ormlite-android
Afinal:https://github.com/yangfuhai/afinal
ActiviteAndroid:https://github.com/pardom/ActiveAndroid
SugarORM:Android 平台专用ORM
GreenDao:https://github.com/greenrobot/greenDAO
Realm:https://github.com/realm/realm-java

解析主角GreenDao&Realm

背景

以上框架我使用过ORMLite&Afinal&GreenDao&Realm,没使用过的我先暂不评价,最开始我准备通过这4个框架的对比为大家进行分析,然而当我写ORMLite的时候,发现其的ORM封装并没有什么大的作用,唯一让我觉得能夸赞一点的地方,ORMLite他不在需要去写表结构以及SQL语句,我们只需配置实体注解以及调用它的DAO进行数据库操作即可,相对于SQLite也仅仅只是这么点优点,仍然需要写大量的封装代码,这点其实已经很不愿意去使用它了,然而他的性能测试,使我完全放弃使用它,跟GreenDao&Realm完全不在一个层级上的,所以直接推荐大家不使用。至于Afinal,他里面还封装了很多其他的功能,也不是我们优选的数据库框架。

接下来轮到GreenDao&Realm登场,他们的实用性与性能如何,我们拿真实数据说话。网络对他们的资料介绍非常模糊,并且参差不齐。
下面我们逐步进行PK

1、开发环境需求

GreenDao: Android Studio即可。
Realm:
来自官方
Make sure make is available in your $PATH
Download the JDK 7 or JDK 8 from Oracle and install it.
Download & install the Android SDK Build-Tools 24.0.0, Android N (API 24) (for example through Android Studio’s Android SDK Manager)
Download the Android NDK (= r10e) for OS X or Linux.

2、版本对比:

GreenDao: org.greenrobot:greendao:3.1.0
Realm:io.realm:realm-android:0.84.1

3、引用方法

GreenDao:

buildscript {
    repositories {
        mavenCentral()
    }
    dependencies {
        classpath 'org.greenrobot:greendao-gradle-plugin:3.1.0'
    }
}

apply plugin: 'org.greenrobot.greendao'

dependencies {
    compile 'org.greenrobot:greendao:3.1.0'
}

Realm V:0.84.1

dependencies {
    compile 'io.realm:realm-android:0.84.1'
}

Realm V:1.1.1

buildscript {
    repositories {
        maven {
            url 'http://oss.jfrog.org/artifactory/oss-snapshot-local'
        }
    }
    dependencies {
        classpath "io.realm:realm-gradle-plugin:<version>-SNAPSHOT"
    }
}

repositories {
    maven {
        url 'http://oss.jfrog.org/artifactory/oss-snapshot-local'
    }
}

3、数据库操作(增删改查)

我们通过Demo使用GreenDao&Realm数据库对相同的数据进行1、10、100、1000、10000、100000条数据同时添加、删除、查询(id,name,age3个字段)观察其性能的真实对比,其它条件完全保持一致,仅计算数据库增删改查的时间。
通过记录大量数据取平均值,记录如下:
这里写图片描述
从这张表中体现出的现象:
在小量数据的查询与删除等操作中,两者的差距基本可以忽略不计,早超过同时插入、删除、查询1000条以上的数据分析得出。GreenDao在删除操作中,占明显优势,而Realm在添加与查询方面优于GreenDAO。

4、使用推荐

由于GreenDao在3.0.1后的使用极其方便,并且使用的习惯与拓展性、稳定性优于Realm,推荐使用GreenDao.
如果你的项目中对添加与查询操作要求极高的话,推荐使用Realm,但它目前相对不稳定,官方也在持续优化中,需留意官网并实时替换新版本。

5、测试截图与测试Demo

下面是1000条数据的测试截图
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述

项目内容:
这里写图片描述
Github下载地址:https://github.com/JackWaiting/GreenDao-Realm

查看评论

greenDAO与Realm的探索

最近项目中要用到数据库相关的知识,就在网上查了下Android平台上的数据库框架,目前比较热门有GreenDAO和Realm,这两个都是使用者都比较多,并且都在持续发布更新,就对这两个框架进行了一些探...
  • w2_2015
  • w2_2015
  • 2017年07月05日 15:55
  • 1013

GreenDao、Ormlite、Realm性能对比

GreenDao、Ormlite、Realm性能对比        该博文为我本人亲测,代码编写过程中使用到了百度上很多大神的demo,如http://blog.csdn.net/shareye19...
  • firesmog
  • firesmog
  • 2017年02月18日 10:01
  • 3244

数据库框架GreenDao——比Realm好一点

说实话android的数据库确实比较难用,尤其是数据量较大的时候。使用的SQL语句可能就比较多了。再加上占位符,体积庞大。于是realm,greendao这些自动建立数据库的就出现了。Realmrea...
  • yu_duan_hun
  • yu_duan_hun
  • 2017年11月03日 15:43
  • 96

HBase 实战中遇到的坑

问题一 : HTable.backgroundFlushCommits; HTable.flushCommits; HTable.close; 解决方案 ,对同一个表进行的操作 htable ...
  • u012944224
  • u012944224
  • 2017年01月20日 13:53
  • 3209

Realm实战总结---Android

数据库一直以来给我的感觉就是——麻烦!!! 接触了Realm之后才终于可以开开心心的使用数据库了。 本文总结一些Realm数据库的常用知识点,包括多线程访问,以及如何与Retrofit2.0一起使用等...
  • javine
  • javine
  • 2016年03月30日 16:50
  • 10121

Android常用数据库ORM框架ORMlite和GreenDao比较

Android常用数据库ORM框架ORMlite和GreenDao比较,包含DEMO工程文件
  • tyyj90
  • tyyj90
  • 2016年01月03日 13:47
  • 4082

greendao数据的使用,简单形

greendao 库,用法 先附上源码类DaoMaster 这个类是可以说是最大的权利,可以这么看,管理库(版本,创建表,增,删 改,创建库) DaoMaster 类 然后,下面还有一...
  • qq_33495943
  • qq_33495943
  • 2017年06月20日 15:13
  • 178

GreenDao、Ormlite、Realm性能对比

原地址:http://blog.csdn.net/firesmog/article/details/55656007GreenDao、Ormlite、Realm性能对比       该博文为我本人亲测...
  • zhangsheXIN_
  • zhangsheXIN_
  • 2018年03月02日 17:04
  • 34

GreenDao数据库框架 最精简使用教程 并对其进行简单封装

GreenDao框架的使用步骤:(android studio)1.首先在project的build.gradle下进行添加如下依赖:dependencies { classpath 'org...
  • zheweixingzhang
  • zheweixingzhang
  • 2016年09月10日 23:08
  • 2644
    个人资料
    专栏达人 持之以恒
    等级:
    访问量: 26万+
    积分: 2688
    排名: 1万+
    博客专栏
    文章分类
    最新评论