服务器-spring mongodb中elemMatch问题

问题描述

spring mongodb中elemMatch问题

写服务器数据库时候有个问题。
要解决的问题是:查询某个用户所在的所有组
例如:群组的数据类型如下:
[
{"_id":0
"members":[
1,3,4,5,6,7
]},
{"_id":1
"members":[
2,4,6,8,11,13
]},
{"_id":2
"members":[
1,7,6,4
]}
]
其中members是一个数组,包含的是每个群组成员的ID号。
现在假如我要查ID是2的用户参与的组。

 Criteria.where("members").elemMatch(Criteria.where("").is(2))

问题就是members这个数组,他里面的元素就是个值,也没有key,里面的criteria怎么都写不对了。
我也试过在shell里面写过类似的语句:
{ "members" : { "$elemMatch" : { "" : 2}}}
不过这是查不出结果的。或者是这么写
{ "members" : { "$elemMatch" : { 2}}}
根本语法就是错的。

解决方案

已经自己解决了,查询方法出乎意料的简单。在这个例子里。直接Criteria.where("members").is(2)就行了

解决方案二:

补充:实际写的时候ID是用ObjectId的,这里为了简化就用了INT

解决方案三:

已经自己解决了,查询方法出乎意料的简单。在这个例子里。直接Criteria.where("members").is(2)就行了

时间: 2024-07-30 12:48:09

服务器-spring mongodb中elemMatch问题的相关文章

springboot(十一):Spring boot中mongodb的使用

mongodb是最早热门非关系数据库的之一,使用也比较普遍,一般会用做离线数据分析来使用,放到内网的居多.由于很多公司使用了云服务,服务器默认都开放了外网地址,导致前一阵子大批 MongoDB 因配置漏洞被攻击,数据被删,引起了人们的注意,感兴趣的可以看看这篇文章:场屠戮MongoDB的盛宴反思:超33000个数据库遭遇入侵勒索,同时也说明了很多公司生产中大量使用mongodb. mongodb简介 MongoDB(来自于英文单词"Humongous",中文含义为"庞大&qu

spring data mongodb 中怎么对日期进行模糊查询

问题描述 spring data mongodb 中怎么对日期进行模糊查询 如keyword="2012" 找到 "time" : ISODate("2012-07-25T03:39:38.000+0000"), 解决方案 spring mongodb 模糊查询配置使用Spring Data MongoDB 解决方案二: 你是要查询2012年内的内容么? 你可以设置最大值和最小值来查gte-lte

《深入实践Spring Boot》一第2章 在Spring Boot中使用数据库2.1 使用MySQL

第2章 在Spring Boot中使用数据库 使用数据库是开发基本应用的基础.借助于开发框架,我们已经不用编写原始的访问数据库的代码,也不用调用JDBC(Java Data Base Connectivity)或者连接池等诸如此类的被称作底层的代码,我们将在高级的层次上访问数据库.而Spring Boot更是突破了以前所有开发框架访问数据库的方法,在前所未有的更加高级的层次上访问数据库.因为Spring Boot包含一个功能强大的资源库,为使用Spring Boot的开发者提供了更加简便的接口进

Http请求中Content-Type讲解以及在Spring MVC中的应用

引言: 在Http请求中,我们每天都在使用Content-type来指定不同格式的请求信息,但是却很少有人去全面了解content-type中允许的值有多少,这里将讲解Content-Type的可用值,以及在Spring MVC中如何使用它们来映射请求信息. Content-Type MediaType,即是Internet Media Type,互联网媒体类型:也叫做MIME类型,在Http协议消息头中,使用Content-Type来表示具体请求中的媒体类型信息. [html] view pl

Spring Boot中集成Spring Security 专题

if语句中条件判断就是检查当前的url请求是否是logout-url的配置值,接下来,获取用户的authentication,并循环调用处理器链中各个处理器的logout()函数,前面在parse阶段说过,处理器链中有两个实例,处理会话的SecurityContextLogoutHandler及remember-me服务,我们来一一看看它们的logout函数实现: 2.1.0 SecurityContextLogoutHandler public void logout(HttpServletR

spring mvc中使用post方式请求返回405

问题描述 spring mvc中使用post方式请求返回405 后台处理方法 @RequestMapping(value=""/doLogin"" method=RequestMethod.POST) public ModelAndView doLogin(HttpSession session){ logger.info(""user login.""); session.setAttribute(""U

Spring MVC 中自定义视图 @Component 及 配置 多个视图解析器 Excel视图

首先我们建立一个自己的View实现View接口.要注意在类上面加上@Component的注解,因为看BeanNameViewResolver的源码知道,是直接从ioc容器里面拿的根据名字拿的视图,所以我们得把我们自己写的视图放到容器里面. HelloView.java package com.hust.springmvc.views; import java.util.Date; import java.util.Map; import javax.servlet.http.HttpServle

springmvc-页面中js跳转URL,与spring mvc中返回视图重定向,先后问题

问题描述 页面中js跳转URL,与spring mvc中返回视图重定向,先后问题 页面中有javascript函数: function mySubmitFn() { /*formname是页面form表单的名字,表单提交后由spring mvc处理,返回一个重定向视图'return new ModelAndView(new RedirectView("A.jsp"));'*/ formname.submit(); //代码1 window.location.href='B.jsp';/

springboot(三):Spring boot中Redis的使用

spring boot对常用的数据库支持外,对nosql 数据库也进行了封装自动化. redis介绍 Redis是目前业界使用最广泛的内存数据存储.相比memcached,Redis支持更丰富的数据结构,例如hashes, lists, sets等,同时支持数据持久化.除此之外,Redis还提供一些类数据库的特性,比如事务,HA,主从库.可以说Redis兼具了缓存系统和数据库的一些特性,因此有着丰富的应用场景.本文介绍Redis在Spring Boot中两个典型的应用场景. 如何使用 1.引入