返回顶部
首页 > 资讯 > 精选 >Android数据库greenDAO如何配置与使用
  • 251
分享到

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

2023-07-05 11:07:50 251人浏览 薄情痞子
摘要

本篇内容主要讲解“Android数据库greenDAO如何配置与使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android数据库greenDAO如何配置与使用”吧!greenDAO是一个针

本篇内容主要讲解“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会自动增长):

@Entitypublic class Province {    @Id    private Long id;    private String provinceName;    private String provinceCode;    }

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

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我们可以对数据库进行增删改查等操作:

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();    }

添加数据

    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);                      }                });        }

删除数据

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

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

修改数据

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

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之间的数据

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:在某个数值之间的范围

到此,相信大家对“Android数据库greenDAO如何配置与使用”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Android数据库greenDAO如何配置与使用

本文链接: https://lsjlt.com/news/351408.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android数据库greenDAO如何配置与使用
    本篇内容主要讲解“Android数据库greenDAO如何配置与使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android数据库greenDAO如何配置与使用”吧!greenDAO是一个针...
    99+
    2023-07-05
  • Android数据库greenDAO配置与使用介绍
    目录build.gradle配置数据库初始化添加数据删除数据修改数据查询数据补充结束不知不觉发现都快一个月没有写点东西了,自己最近也是忙于工作与生活当中,这个月经历了很多事情,有开心...
    99+
    2023-03-12
    Android数据库greenDAO Android greenDAO
  • MySQL数据库如何安装与配置
    本文小编为大家详细介绍“MySQL数据库如何安装与配置”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL数据库如何安装与配置”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.什么是pymysqlPyMyS...
    99+
    2023-06-27
  • Redis使用命令行与多数据库配置
    一、Redis发送命令的两种方式 redis-cli -h localhost -p 6379redis-cli ping 返回pong 证明正常 二、命令返回值 1、状态回复,如p...
    99+
    2024-04-02
  • SpringBoot如何配置数据库
    0 写在前面 项目启动需要一个链接数据库,所以在此记录一下。 根据配置文件的后缀书写格式略有不同。 此处以MySQL为例,使用Maven为例 1 引入依赖 mysql ...
    99+
    2023-08-16
    数据库 spring boot mysql
  • 如何配置mysql数据库
    mysql数据库的配置涉及以下步骤:安装mysql并设置root用户和密码。编辑my.cnf配置文件以配置端口、监听地址、最大连接数和日志位置。设置mysql_home和path环境变量...
    99+
    2024-06-15
    mysql
  • MyBatis如何实现配置MySql数据库与Spring
    这篇文章将为大家详细讲解有关MyBatis如何实现配置MySql数据库与Spring,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.1MyBatis简介   ...
    99+
    2023-05-31
    spring mybatis mysql
  • Linux下如何安装与配置MySQL数据库
    在Linux下安装和配置MySQL数据库可以通过以下步骤完成: 安装MySQL数据库:在终端中输入以下命令安装MySQL数据库: ...
    99+
    2024-05-06
    Linux MySQL
  • Android中如何使用SQLite数据库
    在Android中使用SQLite数据库需要进行以下步骤: 创建一个继承自SQLiteOpenHelper的帮助类来管理数据库的创...
    99+
    2024-04-09
    Android SQLite
  • oracle数据库参数如何配置
    Oracle数据库是一个复杂的系统,需要正确配置参数来保证其性能和稳定性。 以下是一些常见的Oracle数据库参数配置建议: S...
    99+
    2024-04-22
    oracle
  • EF如何配置Oracle数据库
    这篇文章主要介绍了EF如何配置Oracle数据库,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。EF可以配置Oracle数据库,但不知道为什么...
    99+
    2024-04-02
  • 使用druid如何实现配置数据库连接池
    本篇文章为大家展示了使用druid如何实现配置数据库连接池 ,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。druid的配置项如下配置缺省值说明name 配置这个属性的意义在于,如果存在多个...
    99+
    2023-05-31
    数据库连接池 druid
  • 如何在Android中使用SQLite数据库
    本篇文章为大家展示了如何在Android中使用SQLite数据库,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。SQLite简介:SQLite是Android系统采用的一种开源的轻量级的关系型的数据库...
    99+
    2023-05-31
    android sqlite 数据库
  • MYSQL数据库文件与权限应该如何配置
    本文主要给大家简单讲讲MYSQL数据库文件与权限应该如何配置,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望MYSQL数据库文件与权限应该如何配置这篇文章可以...
    99+
    2024-04-02
  • 使用Spring Boot如何实现配置数据库链接池
    使用Spring Boot如何实现配置数据库链接池?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。配置方法基于当前的1.5.2.RELEASE的Spring Boot。依照官方文...
    99+
    2023-05-31
    springboot 数据库 链接池
  • 阿里云如何配置MySQL数据库服务器使用
    本文主要介绍如何在阿里云上配置MySQL数据库服务器。在阿里云上,我们可以轻松地创建、管理、扩展和监控MySQL数据库,以满足我们的业务需求。 一、创建MySQL数据库在阿里云上,我们可以通过ECS服务来创建MySQL数据库。首先,我们需要...
    99+
    2023-11-12
    阿里 服务器 数据库
  • 数据库连接池如何配置
    这篇文章将为大家详细讲解有关数据库连接池如何配置,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、连接池配置1.1 maxWait参数表示从连接池获取连接的超时等待时间,...
    99+
    2024-04-02
  • hibernate如何配置数据库方言
    这篇文章将为大家详细讲解有关hibernate如何配置数据库方言,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。hibernate 配置数据库方言的实现方法,具体如下:RDBMS方言DB2org.hiber...
    99+
    2023-06-15
  • plsql如何配置数据库地址
    在PL/SQL中,可以通过配置Oracle数据库的连接信息来指定数据库地址。你可以使用以下两种方式之一来配置数据库地址:1. 使用O...
    99+
    2023-09-05
    plsql 数据库
  • mysql如何查看数据库配置
    要查看MySQL数据库的配置,可以使用以下步骤: 登录到MySQL数据库服务器上,可以使用命令行工具或者图形化工具。 运行以...
    99+
    2024-04-17
    mysql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作