Android数据库greenDAO如何配置与使用

其他教程   发布日期:2023年08月22日   浏览次数:401

本篇内容主要讲解“Android数据库greenDAO如何配置与使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android数据库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. @Entity
  2. public class Province {
  3. @Id
  4. private Long id;
  5. private String provinceName;
  6. private String provinceCode;
  7. }

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

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

如果我们想要操作实体类是需要要通过DAO来操作,比如我们想要操作

  1. Province
实体类,那我们必须先得到一个
  1. ProvinceDao
,通过
  1. ProvinceDao
我们可以对数据库进行增删改查等操作:
  1. private ProvinceDao provinceDao;
  2. @Override
  3. protected void onCreate(@Nullable Bundle savedInstanceState) {
  4. super.onCreate(savedInstanceState);
  5. setContentView(R.layout.activity_mine_fix_school);
  6. DaoSession daoSession = ((App) getApplication()).getDaoSession();
  7. provinceDao = daoSession.getProvinceDao();
  8. }

添加数据

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

删除数据

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

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

修改数据

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

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

查询数据

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

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

补充

  • eq:等于

  • notEq:不等于

  • gt:大于

  • lt:小于ge:大于等于

  • le:小于等于

  • between:在某个数值之间的范围

以上就是Android数据库greenDAO如何配置与使用的详细内容,更多关于Android数据库greenDAO如何配置与使用的资料请关注九品源码其它相关文章!