【Spring连载】使用Spring Data访问 MongoDB----Template API 查询Documents

【Spring连载】使用Spring Data访问 MongoDB----Template API 查询Documents

  • 一、 查询集合中的Documents
  • 二 选择字段
  • 三、 其他查询选项
    • 3.1 Hints
    • 3.2 游标批大小Cursor Batch Size
    • 3.3 Collations
    • 3.4 读取首选项Read Preference
    • 3.5 Comments
  • 四、查询Distinct值
  • 五、Geo-near 查询
  • 六、GeoJSON 支持
  • 七、域类中的GeoJSON类型
  • 八、存储库查询方法中的GeoJSON 类型
  • 九、度量和距离计算
  • 十、全文检索
  • 十一、Query by Example
  • 十二、查询一个集合以匹配JSON Schema

你可以使用Query和Criteria类来表达查询。它们的方法名称反映了native MongoDB操作名称,如lt、lte、is和其他名称。Query和Criteria类遵循fluent API风格,因此你可以将多个方法标准和查询链接在一起,同时拥有易于理解的代码。为了提高可读性,静态导入可以避免在创建查询和条件实例时使用“new”关键字。你还可以使用BasicQuery从纯JSON字符串创建Query实例,如下例所示:
例1:从纯JSON字符串创建查询实例

BasicQuery query = new BasicQuery("{ age : { $lt : 50 }, accounts.balance : { $gt : 1000.00 }}");
List<Person> result = mongoTemplate.find(query, Person.class);

一、 查询集合中的Documents

在之前的章节,我们看到了如何在MongoTemplate上使用findOne和findById方法来检索单个文档。这些方法以正确的方式返回单个域对象,或者使用响应式(reactive )API Mono发出单个元素。我们还可以查询要作为域对象列表返回的documents集合。假设我们在一个集合中有许多具有姓名和年龄的Person对象作为documents存储,并且每个人都有一个带有余额的内嵌的帐户document,我们现在可以使用以下代码运行查询:
使用MongoTemplate查询文档

// ...List<Person> result = template.query(Person.class).matching(query(where("age").lt(50).and("accounts.balance").gt(1000.00d))).all();

所有find方法都将Query对象作为参数。此对象定义用于执行查询的条件和选项。通过使用Criteria对象来指定条件,该对象具有一个名为where的静态工厂方法来实例化新的Criteria。我们建议对org.springframework.data.mongodb.core.query.Criteria.where和Query.query使用静态导入,使查询更具可读性。
查询应该返回符合指定条件的Person对象的List或Flux。本节的剩余部分列出了与MongoDB中提供的运算符相对应的Criteria和Query类的方法。大多数方法返回Criteria对象,为API提供流畅的样式。
Criteria的方法
Criteria类提供了以下方法,所有这些方法都对应于MongoDB中的运算符:

  • Criteria all (Object o)使用$all运算符创建一个条件
  • Criteria and (String key)将具有指定key的链式Criteria添加到当前Criteria并返回新创建的Criteria
  • Criteria andOperator (Criteria…​ criteria)使用$and运算符为所有提供的条件创建and查询
  • Criteria andOperator (Collection< Criteria> criteria)使用$and运算符为所有提供的条件创建and查询
  • Criteria elemMatch (Criteria c)使用$elemMatch运算符创建条件
  • Criteria exists (boolean b)使用$exists运算符创建条件
  • Criteria gt (Object o)使用$gt运算符创建条件
  • Criteria gte (Object o)使用$gte运算符创建条件
  • Criteria in (Object…​ o) 使用$in运算符为varargs参数创建一个条件。
  • Criteria in (Collection<?> collection)使用$in运算符并使用集合创建条件
  • Criteria is (Object o)使用字段匹配({key:value})创建条件。如果指定的值是一个document,则字段的顺序和document中的完全相等性很重要。
  • Criteria lt (Object o)使用$lt运算符创建条件
  • Criteria lte (Object o)使用$lte运算符创建一个条件
  • Criteria mod (Number value, Number remainder)使用$mod运算符创建一个条件
  • Criteria ne (Object o)使用$ne运算符创建条件
  • Criteria nin (Object…​ o)使用$nin运算符创建条件
  • Criteria norOperator (Criteria…​ criteria)为所有提供的条件使用$nor运算符创建nor查询
  • Criteria norOperator(Collection<Criteria>Criteria)为所有提供的条件使用$nor运算符创建nor查询
  • Criteria not ()使用$not元运算符创建一个条件,该运算符直接影响后面的子句
  • Criteria orOperator (Criteria…​ criteria)为所有提供的条件使用$or运算符创建or查询
  • Criteria orOperator (Collection< Criteria> criteria)使用$或运算符为所有提供的条件创建或查询
  • Criteria regex (String re)使用$regex创建条件
  • Criteria sampleRate (double sampleRate)使用$sampleRate运算符创建条件
  • Criteria size (int s)使用$size运算符创建条件
  • Criteria type (int t)使用$type运算符创建条件
  • Criteria matchingDocumentStructure (MongoJsonSchema schema)使用 $ jsonSchema 运算符为JSON schema criteria创建一个条件。$jsonSchema只能应用于查询的顶层,而不能应用于特定属性。使用schema的properties属性来匹配嵌套字段。
  • Criteria bits() 是调用MongoDB bitwise query operators(如$bitsAllClear)的网关。

Criteria类还提供了以下用于地理空间查询的方法。

  • Criteria within (Circle circle)使用$geoWithin $center操作符创建地理空间条件。
  • Criteria within (Box box)使用$geoWithin $box操作创建地理空间条件。
  • Criteria withinSphere (Circle circle)使用$geoWithin $center操作符创建地理空间条件。
  • Criteria near (Point point)使用$near操作创建地理空间条件
  • Criteria nearSphere (Point point)使用$nearSphere $center操作创建地理空间条件。
  • Criteria minDistance (double minDistance)使用 $ minDistance 操作创建地理空间条件,与$near一同使用。
  • Criteria maxDistance (double maxDistance)使用 $ maxDistance 操作创建地理空间条件,与$near一同使用。

Query类有一些附加的方法,这些方法允许选择某些字段以及对结果进行limit和排序。
Query类的方法

  • Query addCriteria (Criteria criteria),用于向查询添加其他条件
  • Field fields (),用于定义要包含在查询结果中的字段
  • Query limit (int limit)用于将返回结果的大小限制为提供的limit (用于分页)
  • Query skip(int skip)用于跳过结果中提供的documents数(用于分页)
  • Query with (Sort sort)用于为结果提供排序定义
  • Query with (ScrollPosition position)用于提供滚动(Scroll)位置(基于Offset或Keyset的分页)以开始或恢复滚动

template API允许直接使用结果投影,使你能够将查询映射到给定的域类型,同时将操作结果投影到另一个域类型,如下所述。

classtemplate.query(SWCharacter.class).as(Jedi.class)

有关结果投影的更多信息,请参阅Spring Data Projections的文档。

二 选择字段

MongoDB支持投影查询返回的字段。投影可以根据字段的名称包括和排除字段(除非明确排除,否则始终包括_id字段)。
例2:选择结果字段

public class Person {@Id String id;String firstname;@Field("last_name")String lastname;Address address;
}
query.fields().include("lastname");              --------1query.fields().exclude("id").include("lastname") --------2query.fields().include("address")                --------3query.fields().include("address.city")           --------41. 通过{“last_name”:1,结果将同时包含_id和last_name。
2. 通过{“_id”:0,“last_name”:1,结果将仅包含last_name 。
3. 通过{“address”:1}结果将包含_id和整个地址对象。
4. 通过{“address.city”:1,结果将包含_id和address对象,该address仅包含city字段。

从MongoDB 4.4开始,你可以使用聚合表达式进行字段投影,如下所示:
例3:使用表达式计算结果字段

query.fields().project(MongoExpression.create("'$toUpper' : '$last_name'"))         --------1.as("last_name");                                                     --------2query.fields().project(StringOperators.valueOf("lastname").toUpper())               --------3.as("last_name");query.fields().project(AggregationSpELExpression.expressionOf("toUpper(lastname)")) --------4.as("last_name");1. 使用native表达式。使用的字段名称必须引用数据库document中的字段名称。
2. 指定表达式结果投影到的字段名称。生成的字段名称未映射到域模型。
3. 使用聚合表达式。除了native MongoExpression之外,字段名被映射到域模型中使用的字段名。
4.SpELAggregationExpression一起使用可以调用表达式函数。字段名称将映射到域模型中使用的字段名称。

@Query(fields=“…”)允许在存储库级别使用表达式字段投影,如MongoDB JSON-based Query Methods and Field Restriction中所述。

三、 其他查询选项

3.1 Hints

3.2 游标批大小Cursor Batch Size

3.3 Collations

3.4 读取首选项Read Preference

3.5 Comments

四、查询Distinct值

五、Geo-near 查询

六、GeoJSON 支持

七、域类中的GeoJSON类型

八、存储库查询方法中的GeoJSON 类型

九、度量和距离计算

十、全文检索

十一、Query by Example

十二、查询一个集合以匹配JSON Schema

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/704764.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

小龙虾优化算法COA求解不闭合SD-MTSP,可以修改旅行商个数及起点(提供MATLAB代码)

一、小龙虾优化算法COA 小龙虾优化算法&#xff08;Crayfsh optimization algorithm&#xff0c;COA&#xff09;由Jia Heming 等人于2023年提出&#xff0c;该算法模拟小龙虾的避暑、竞争和觅食行为&#xff0c;具有搜索速度快&#xff0c;搜索能力强&#xff0c;能够有效平衡…

★【递归】【构造二叉树】Leetcode 106.从中序与后序遍历序列构造二叉树

★【递归】【构造二叉树】Leetcode 106.从中序与后序遍历序列构造二叉树 105. 从前序与中序遍历序列构造二叉树 106.从中序与后序遍历序列构造二叉树:star:思路分析递归解法 105. 从前序与中序遍历序列构造二叉树递归解法 ---------------&#x1f388;&#x1f388;题目链接&a…

计算机网络-IP网络划分专题

1.8421法二转十&#xff08;连加&#xff09;或十转二&#xff08;连减&#xff09; 如下图&#xff1a; 2.IP地址 4个字节32位。每一个8位组用0~255表示。因此&#xff0c;最小的IP地址值为0.0.0.0&#xff0c;最大的地址值为255.255.255.255。 3.位数和个数的关系&#xff…

内核中断体系概括

文章目录 前言一、Linux的中断机制1、分类2、代码结构 二、中断的工作流程1、中断的工作流程2、Linux 中中断的工作流程3、中断的代码实现过程 三、内核中断体系结构 前言 本文对内核中断进行概括以及讲述中断的具体实现方法在内核是怎么做的&#xff0c;会结合内核源码中的一…

【Flink】Flink 中的时间和窗口之窗口(Window)

1. 窗口的概念 Flink是一种流式计算引擎&#xff0c;主要是来处理无界数据流&#xff0c;数据流的数据是一直都有的&#xff0c;等待流结束输入数据获取所有的流数据在做聚合计算是不可能的。为了更方便高效的处理无界流&#xff0c;一种方式就是把无限的流数据切割成有限的数…

c语言-day1(ubuntu操作系统及指令)

1&#xff1a;思维导图 2&#xff1a; &#xff08;1&#xff09;&#xff1a; &#xff08;2&#xff09; &#xff08;3&#xff09; &#xff08;4&#xff09; &#xff08;5&#xff09;

通过盲注脚本复习sqllabs第46关 order by 注入

sql-lab-46 order by 注入是指其后面的参数是可控的&#xff0c; order by 不同于我们在 where 后的注入点&#xff0c;不能使用 union 等注入&#xff0c;其后可以跟接 报错注入 或者 时间盲注。 数字型order by注入时,语句order by2 and 12,和order by2 and 11显示的结果一…

C语言KR圣经笔记 8.5样例 - fopen和getc的实现

8.5 样例 - fopen 和 getc 的实现 通过给出标准库例程 fopen 和 getc 的一个实现&#xff0c;我们来说明如何将前面这些内容组合起来。 回忆一下&#xff0c;在标准库中&#xff0c;文件用文件指针而不是文件描述符来描述。文件指针是包含一些文件信息的结构体指针&#xff1…

金融贷款风险预测:使用图神经网络模型进行违约概率评估

要使用PyTorch和GNN&#xff08;图神经网络&#xff09;来预测金融贷款风险&#xff0c;并加入注意力机制&#xff0c;我们首先需要构建一个贷款风险预测的图数据集。然后&#xff0c;我们将设计一个基于注意力机制的GNN模型。 以下是一个简化的代码示例&#xff0c;演示了如何…

前端框架的CSS模块化(CSS Modules)

创作纪念日之际&#xff0c;来给大家分享一篇文章吧 聚沙成塔每天进步一点点 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们…

Vue前端对请假模块——请假开始时间和请假结束时间的校验处理

开发背景&#xff1a;Vueelement组件开发 业务需求&#xff1a;用户提交请假申请单&#xff0c;请假申请的业务逻辑处理 实现&#xff1a;用户选择开始时间需要大于本地时间&#xff0c;不得大于请假结束时间&#xff0c;请假时长根据每日工作时间实现累加计算 页面布局 在前…

Linux socket函数

什么是协议 在网络编程中&#xff0c;协议是指计算机系统之间进行通信和交互所遵循的规则和约定。它定义了数据的格式、传输方式、错误处理、认证和授权等方面的规范&#xff0c;以确保不同计算机之间能够正确地交换信息。 协议分为多个层次&#xff0c;每个层次负责不同的功…

二进制部署k8s之网络部分

1 CNI 网络组件 1.1 K8S的三种接口 CRI 容器运行时接口 docker containerd podman cri-o CNI 容器网络接口 flannel calico cilium CSI 容器存储接口 nfs ceph gfs oss s3 minio 1.2 K8S的三种网络 节点网络 nodeIP 物理网卡的IP实现节点间的通信 Pod网络 podIP Pod与Po…

视频和音频使用ffmpeg进行合并和分离(MP4)

1.下载ffmpeg 官网地址&#xff1a;https://ffmpeg.org/download.html 2.配置环境变量 此电脑右键点击 属性 - 高级系统配置 -高级 -环境变量 - 系统变量 path 新增 文件的bin路径 3.验证配置成功 ffmpeg -version 返回版本信息说明配置成功4.执行合并 ffmpeg -i 武家坡20…

GOOGLE Colab Pro会员订阅开通购买付费充值教程

一、简介 colab由谷歌团队开发&#xff0c;用于机器学习、数据分析&#xff0c;教育等目的&#xff0c;他的会员也非常的昂贵&#xff0c;最基本的套餐要10美金&#xff0c;最高要50美金一个月&#xff0c;如何省钱&#xff0c;往下看。 一般来说土区的价格比较便宜&#xff0…

Day02:Web架构前后端分离站Docker容器站集成软件站建站分配

目录 常规化站点部署 站库分离 前后端分离 集成软件搭建Web应用 Docker容器搭建Web应用 建立分配站 静态 与 伪静态 总结 章节知识点&#xff1a; 应用架构&#xff1a;Web/APP/云应用/三方服务/负载均衡等 安全产品&#xff1a;CDN/WAF/IDS/IPS/蜜罐/防火墙/杀毒等 渗…

基于单片机的企业指纹考勤系统设计

摘要: 考勤系统是企业人力资源管理的重要依据,传统的考勤系统不能保证准确性,也存在地域局限,不能满足一些跨区域集团公司的考勤要求。文章以单片机技术以及生物特征识别技术为基础,分析企业单片机智能化指纹考勤系统的设计思路,从硬件设备的选型和配置、软件系统的开发、…

ES6 对象面试题

ES6 对象面试题 问题描述&#xff1a; 什么是对象的简洁表示法&#xff08;Shorthand Property&#xff09;&#xff1f;给出一个使用简洁表示法的示例。 答案&#xff1a; 对象的简洁表示法是一种在对象字面量中定义属性的简化语法。当属性名和变量名相同时&#xff0c;可以省…

怎么把pdf转换成word?

怎么把pdf转换成word&#xff1f;Pdf和word在电脑上的使用非常广泛&#xff0c;pdf和word分别是由 Adobe和Microsoft 分别开发的电脑文件格式。PDF 文件可以在不同操作系统和设备上保持一致的显示效果&#xff0c;无论是在 Windows、Mac 还是移动设备上查看&#xff0c;都能保持…

【学习笔记】SCI投稿状态

大多数SCI期刊都有自己的在线投稿系统&#xff0c;如ScholarOne Manuscripts、Editorial Manager等&#xff0c;这些系统使得投稿、审稿、编辑和出版过程变得更加高效和透明。投稿系统通常要求作者注册账户&#xff0c;然后根据指导逐步提交稿件及相关信息。 投稿状态介绍 Sub…