Android中GreenDao数据库框架的使用

2024-01-14 03:58

本文主要是介绍Android中GreenDao数据库框架的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

之前就用过这个数据库框架,一直没有事件写出来,今天终于有时间记录下啦。现在用的是3.2的版本,故以GreenDao的3.2的版本为主,记录下自己对这个框架的使用。

1、了解GreenDao3.2

1)orm是对象与数据的映射,简而言之就是让java实体与数据库建立绑定的联系;

2)我们所熟知的数据库又可分之为层次式数据库网络式数据库关系式数据库三种,然而我们在使用时有经常分为关系型和非关系型两种;

关系型数据库有如下几种:orcal、mysql、dbll、sybase

非关系型数据库有如下几种:hbase、mongodb、redis

2、我们今天所说的这种数据库框架就属于基于Android内部的Sqlite封装的关系型数据库,它 是一款开源的面向 Android 的轻便、快捷的 ORM 框架,将 Java 对象映射到 SQLite  数据库中,我们操作数据库的时候,不在需要编写复杂的 SQL语句, 在性能方面,GreenDao 针对 Android 进行了高度优化,  最小的内存开销 、依赖体积小 同时还是支持数据库加密。

3、官网地址:http://greenrobot.org/greendao/;源码地址:github 地址:https://github.com/greenrobot/greenDAO

4、GreenDao的特征

1)、GreenDao是ORM框架,便于java对象映射到Sqlite数据库中保存(对象映射ORM);

2)、高性能

3)、支持加密:能够安全的保存用户的信息到数据库

4)、轻量级:GreenDao  核心库小于100k ,故我们并不会担心添加 GreenDao  后 APK 大小会变的是否庞大。

5)、开源代码自动生成:根据配置信息自动生成核心管理类以及 DAO 对象

5、GreenDao在Android中的配置

5.1设置仓库与配置(在progect目录下的build.gradle)


5.2配置依赖关系(在app目录下的build.gradle)

添加插件、配置


添加GreenDao的引用


5.3点击Sync Progect Width Gradle Files 完成配置

6、入门

6.1我们写一个简单的实体,试下效果:


6.2点击 Make Project(或者RebuildProgect或CleanProgect) 编译一下工程或者刷新下gradle 。如果配置正确,会在配置的包目录下自动会生成 DaoMaster,DaoSession 和 UserDao 类

entity其他属性的使用


6.3、GreenDao在自定义的Application中的引用


6.4、数据的增删改查

7、GreenDao注解的解析:

@Entity 实体会在数据库中生成一个与其对应的表

实体类中添加的注解字段:

 schema:告知GreenDao当前实体属于哪个 schema

    schema active:标记一个实体处于活跃状态,活动实体有更新、删除和刷新方法

    nameInDb:在数据库中使用的别名,默认使用的是实体的类名,

    indexes:定义索引,可以跨越多个列

    createInDb:标记创建数据库表(默认:true)

    generateConstructors  自动创建全参构造方法(同时会生成一个无参构造方法)(默认:true)

    generateGettersSetters  自动生成 getters and setters 方法(默认:true)

@Id对应数据库表中的字段

@Index 使用@Index作为一个属性来创建一个索引,默认是使用字段名

@Unique表名该属性在数据库中只能有唯一值

@Transient 添加此标记后不会生成数据库表的列

@ToOne表示一对一关系

@ToMany定义一对多个实体对象的关系

@OrderBy 更加某一字段排序 ,例如:@OrderBy("date ASC")

@NotNull  设置数据库表当前列不能为空

 @Property设置一个非默认关系映射所对应的列名,默认是使用字段名,例如:@Property(nameInDb = "userName")

以上就是所有的内容,再遇到新的再补充

源码下载地址:https://download.csdn.net/download/smxueer/10361024










这篇关于Android中GreenDao数据库框架的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/603858

相关文章

golang1.23版本之前 Timer Reset方法无法正确使用

《golang1.23版本之前TimerReset方法无法正确使用》在Go1.23之前,使用`time.Reset`函数时需要先调用`Stop`并明确从timer的channel中抽取出东西,以避... 目录golang1.23 之前 Reset ​到底有什么问题golang1.23 之前到底应该如何正确的

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的