GreenDao-基本使用

2024-05-29 00:38
文章标签 使用 基本 greendao

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

在上一节中我们介绍了greendao的环境搭建以及简单的工具类封装接下来我们介绍greendao的基本使用。
不熟悉的同学可以打开如下链接

greendao的环境配置

1.greendao的添加语法
语法很简单基本的使用如下(这里我们沿用上节的user,以及userDao)

 UserDao dao = MarsKangDbManager.getDataBaseInstance().getUserDao();User user1 = new User( 2,"abc", "123", "001");dao.insert(user1); 

2.greendao的查询语法
首先我们来看一个简单的查询

List<User> users=dao.queryBuilder().where(UserDao.Properties.UserName.like("abc")).orderAsc(UserDao.Properties.UserName,UserDao.Properties.PassWord).list();int sum=users.size();

where 语句的意思就是通过我们的UserDao获取到Properties的属性UserName包含abd的内容
也就是查询user表usernam这个字段包含abc的记录。
orderAsc 语句的意思就是通过我们的UserDao获取到Properties的属性UserName,以及通过我们的UserDao获取到Properties的属性PassWord 首先通过UserName正序排列然后通过PassWord 正序排列实现结果集排序的目的。
list 很容易理解就是将结果存放到list中去返回给users对象。
接下来我们来看个复杂点的查询

  QueryBuilder<User> qb = dao.queryBuilder();qb.where(UserDao.Properties.UserName.eq("abc"),qb.or(UserDao.Properties.Id.between(0, 2), UserDao.Properties.UserPower.eq("001")),qb.and(UserDao.Properties.UserName.in("abc"), UserDao.Properties.UserPower.isNotNull()));List<User> users=qb.list();int sum=users.size();

跟上面的原理一样我们通过where语句包裹需要的所有条件
1.用户名=abc
2.用户ID在0到2之间或者用户权限=001
3.用户名包含abc并且用户权限不为null
当然如果我们要限制结果集的内容我们可以这样做

 List<User> users=qb.limit(2).offset(1).list();
int sum=users.size();

在得到结果集之前加上limit(2)代表限制查询数量为为2条默认是从第1条开始.offset(1)代表从第2条开始查询,查询第2,3条数据。

3.greenDao复杂查询

  String sql=" left join USER u on u._id = T.USER_ID  ";Query<Student> students=sdao.queryRawCreate(sql);List<Student> students1=students.list();

这样我们就通过sql查询到了我们想要的结果了
但是我们同事也发现了greenDao的缺点
1.它的join方法只是支持内联而且还得是主键内联
2.它不能定义我们所需要返回的实体类型
可能做完这些需要greendao的工程师们花费一些精力以及时间去完成,作为开发者如果我们的app本地对数据查询复杂度要求很高的话可以使用greendao提升开发效率,如果对于查询比较多查询内容比较负责的应用建议先不使用greendao作为我们的数据库框架。

这篇关于GreenDao-基本使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python的端到端测试框架SeleniumBase使用解读

《Python的端到端测试框架SeleniumBase使用解读》:本文主要介绍Python的端到端测试框架SeleniumBase使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录SeleniumBase详细介绍及用法指南什么是 SeleniumBase?SeleniumBase

Java继承映射的三种使用方法示例

《Java继承映射的三种使用方法示例》继承在Java中扮演着重要的角色,它允许我们创建一个类(子类),该类继承另一个类(父类)的所有属性和方法,:本文主要介绍Java继承映射的三种使用方法示例,需... 目录前言一、单表继承(Single Table Inheritance)1-1、原理1-2、使用方法1-

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

SQL BETWEEN 语句的基本用法详解

《SQLBETWEEN语句的基本用法详解》SQLBETWEEN语句是一个用于在SQL查询中指定查询条件的重要工具,它允许用户指定一个范围,用于筛选符合特定条件的记录,本文将详细介绍BETWEEN语... 目录概述BETWEEN 语句的基本用法BETWEEN 语句的示例示例 1:查询年龄在 20 到 30 岁

python使用库爬取m3u8文件的示例

《python使用库爬取m3u8文件的示例》本文主要介绍了python使用库爬取m3u8文件的示例,可以使用requests、m3u8、ffmpeg等库,实现获取、解析、下载视频片段并合并等步骤,具有... 目录一、准备工作二、获取m3u8文件内容三、解析m3u8文件四、下载视频片段五、合并视频片段六、错误

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

nginx启动命令和默认配置文件的使用

《nginx启动命令和默认配置文件的使用》:本文主要介绍nginx启动命令和默认配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录常见命令nginx.conf配置文件location匹配规则图片服务器总结常见命令# 默认配置文件启动./nginx