DetailsOfModelResults mongoTemplateOnes = mongoTemplate.findOne(new Query().addCriteria(Criteria.where("custId").is("28143476408589835").and("dataDate").is("20230608").and("modelId").is("129")), DetailsOfModelResults.class);相同的代码 换了一个服务 结果为什么是null
时间: 2023-07-19 11:58:26 浏览: 69
可能有多种原因导致查询结果为null,以下是一些可能的原因:
1. 数据库连接失败:请确保新的服务与数据库连接正常,且数据库中存在符合条件的数据。
2. 数据库中没有符合条件的数据:请检查数据是否存在,并确保查询条件正确。
3. 数据库权限问题:请确保新的服务拥有正确的数据库权限,以允许查询数据。
4. 数据库表结构不同:请确保新的服务所使用的数据库表结构与旧服务相同,以允许正确查询数据。
您可以根据以上原因依次排查,找到问题所在并进行修复。
相关问题
return mongoTemplate.find (new Query(Criteria.where("number").is(name)), gene.class);
这是一个返回 MongoDB 数据库中 number 字段值为 name 的 gene 类型数据的查询语句。它使用 mongoTemplate 对象的 find 方法执行查询,传入一个 Query 对象作为查询条件,该 Query 对象使用 Criteria 构造器创建了一个 where 子句,限定 number 字段为指定的值 name。最后指定返回的数据类型为 gene.class。
public void save(MgBrowseRecordVo t) { Query query = new Query(); query.addCriteria(Criteria.where("sessionId").is(t.getSessionId())); query.addCriteria(Criteria.where("userName").is(t.getUserName())); query.addCriteria(Criteria.where("modelId").is(t.getModelId())); query.addCriteria(Criteria.where("mallId").is(t.getMallId())); List<MgBrowseRecordVo> list = mongoTemplate.find(query, MgBrowseRecordVo.class, collectionName); if (!EmptyUtils.isEmptyList(list)) { Update update = Update.update("rtime", t.getRtime()); mongoTemplate.upsert(query, update, MgBrowseRecordVo.class, collectionName); } else { mongoTemplate.save(t, collectionName); } }
这段代码是一个保存浏览记录的方法。它使用了Spring Data MongoDB来与MongoDB数据库进行交互。
首先,它创建了一个查询对象`query`,并添加了一些查询条件,包括`sessionId`、`userName`、`modelId`和`mallId`。
然后,通过调用`mongoTemplate.find()`方法,执行查询操作,将满足条件的浏览记录返回到列表`list`中。
接下来,通过判断列表`list`是否为空来确定是执行更新操作还是插入操作。
如果列表`list`不为空,说明已经存在满足条件的浏览记录,就创建一个更新对象`update`,将浏览时间`rtime`更新为新的值,并调用`mongoTemplate.upsert()`方法执行更新操作。
如果列表`list`为空,说明不存在满足条件的浏览记录,就直接调用`mongoTemplate.save()`方法将新的浏览记录保存到数据库中。
需要注意的是,这段代码中使用了一些自定义的类和方法,如`MgBrowseRecordVo`和`EmptyUtils.isEmptyList()`,你可能需要根据具体情况进行替换或添加相应的实现。
阅读全文
相关推荐

















