Android数据库greenDAO配置与使用介绍

2024-01-28 0 748 百度已收录

不知不觉发现都快一个月没有写点东西了,自己最近也是忙于工作与生活当中,这个月经历了很多事情,有开心的也有悲伤的。还好一切都过来了,空下来时想着写点什么好呢,就想着把工作中自己比较喜欢使用的一款有关数据库的开源框架greenDAO,分享下自己的使用过程。

greenDAO是一个针对Android的轻而快速的ORM,它将对象映射到SQLite数据库。由于对Android进行了高度优化,greenDAO提供了出色的性能,并且消耗了最少的内存。

build.gradle配置

buildscript {
repositories {
jcenter()
mavenCentral()
}

dependencies {
classpath ‘com.android.tools.build:gradle:2.3.1’
classpath ‘org.greenrobot:greendao-gradle-plugin:3.2.2’
}
}

apply plugin: ‘com.android.application’
apply plugin: ‘org.greenrobot.greendao’

android {
buildToolsVersion ‘25.0.2’
compileSdkVersion 25

defaultConfig {
applicationId “org.greenrobot.greendao.example”
minSdkVersion 15
targetSdkVersion 25
versionCode 1
versionName “3”

testInstrumentationRunner “android.test.InstrumentationTestRunner”
}
}

greendao {
schemaVersion 1000
}

dependencies {
compile ‘org.greenrobot:greendao:3.2.2’

// 这里当我们使用加密的数据库时就必须添加这条依赖
compile ‘net.zetetic:android-database-sqlcipher:3.5.6’

compile ‘com.android.support:appcompat-v7:25.3.1’
compile ‘com.android.support:recyclerview-v7:25.3.1’
}

uploadArchives.enabled = false

数据库初始化

配置成功后,我们需要创建一个实体类用来生成对应的表,@Entity表示这个实体类一会会在数据库中生成对应的表,@Id表示该字段是id(设置Long类型表示id会自动增长):

1
2
3
4
5
6
7
@Entity
public class Province {
    @Id
    private Long id;
    private String provinceName;
    private String provinceCode;
    }

写完这些之后将项目进行编译:Build—Make Project,编译成功之后系统会帮助我们生成相应的构造方法和get/set方法,并且还会在我们的包下生成DaoMaster和DaoSession。下面我们就可以对数据库进行初始化了:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public class App extends Application {
    //这里我们定义一个标志,从而去切换数据库的标准模式和加密模式
    public static final boolean ENCRYPTED = true;
    private DaoSession daoSession;
    @Override
    public void onCreate() {
        super.onCreate();
        DevOpenHelper helper = new DevOpenHelper(this, ENCRYPTED ? "province-db-encrypted" : "province-db");
        Database db = ENCRYPTED ? helper.getEncryptedWritableDb("super-secret") : helper.getWritableDb();
        daoSession = new DaoMaster(db).newSession();
    }
    public DaoSession getDaoSession() {
        return daoSession;
    }
}

如果我们想要操作实体类是需要要通过DAO来操作,比如我们想要操作Province实体类,那我们必须先得到一个ProvinceDao,通过ProvinceDao我们可以对数据库进行增删改查等操作:

1
2
3
4
5
6
7
8
private ProvinceDao provinceDao;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_mine_fix_school);
        DaoSession daoSession = ((App) getApplication()).getDaoSession();
        provinceDao = daoSession.getProvinceDao();
    }

添加数据

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
List<Province> provinceList = provinceDao.queryBuilder().build().list();
    if (provinceList.size() > 0) {
        //数据库有数据时进行处理
    }else {
        //数据库无数据时,获取网络数据进行数据存储
        api.areas(areaCode)
            .subscribeOn(Schedulers.io())
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(new MySubscriber<List<Province>>() {
                @Override
                public void onNext(List<Province> provinceList) {
                  for (Province province : provinceList) {
                       //插入数据
                       provinceDao.insert(province);
                  }
            });
    }

删除数据

其实删除数据和修改数据是一样的思路,我们要先查找到数据,然后再对数据进行操作:

1
2
3
4
for (Province province : provinceList) {
        //删除数据
        provinceDao.delete(province);
    }

修改数据

这里我只添加了一个查询条件,就是是id于等于10,最后的unique表示只查询一条数据出来即可:

1
2
3
4
5
6
7
8
Province province = provinceDao.queryBuilder().where(ProvinceDao.Properties.ProvinceCode.eq(10)).build().unique();
        if (province == null) {
            //用户不存在
        }else {
            province.setProvinceName("修改浙江省");
            //修改数据
            provinceDao.update(province);
        }

查询数据

其实上面删除和修改都已经涉及到查询了,查询里边有许多非常好用的函数,这里我只用到了一个between表示查询id介于10到20之间的数据

1
2
3
4
5
List<Province> provinces = provinceDao.queryBuilder().where(ProvinceDao.Properties.ProvinceCode.between(10, 20)).build().list();
        for (Province province : provinces) {
            //输出查询内容
            Log.d("TAG","search:" + province.getProvinceName());
        }

补充

  • eq:等于
  • notEq:不等于
  • gt:大于
  • lt:小于ge:大于等于
  • le:小于等于
  • between:在某个数值之间的范围

结束

好了,到这里greenDAO的一些简单的功能就可以实现了,在工作的过程中用到了许多数据库,无论是自己用原生的去写,还是去使用一些开源框架。到现在感觉greenDAO应该算是很好用的一款开源框架,自己也很是喜欢。更想进一步的去探究它的奥秘。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开支付宝扫一扫,即可进行扫码打赏哦,您的支持,是我继续创作的动力。
点赞 (0)

中和威客保留所有权利,未经本站书面许可不得转载本站内容!文中观点不代表本站立场!

中和威客 Android Android数据库greenDAO配置与使用介绍 https://www.izhwk.com/archives/105

Android数据库greenDAO配置与使用介绍
下一篇:

已经没有下一篇了!

常见问题
  • 您需要注册成为本站会员,然后再通过会员中心的升级VIP功能,方可成为本站的VIP会员。
查看详情
  • 首先您需要注册成为本站会员,然后到会员中心充值,充值后支付对应资源的查看金额即可查看付费内容。
查看详情

相关文章

评论
暂无评论
Android数据库greenDAO配置与使用介绍-海报

分享本文封面