spring-data-MongoDB 更新的有关问题(1.0.0 M2) - 数据库

19 篇文章 0 订阅

spring-data-MongoDB 更新的问题(1.0.0 M2)

下午遇到一个问题,用spring data去更新MongDB

在使用的过程中 用的是 mongoTemolate.updateFirst()的方法:

mongoTemplate.updateFirst(new Query (Criteria.where("name").is("miller")),new Update().set("name","miller_cn"));

这些都是没有问题了 ,都能成功的更新数据库。

在后来遇到一个非常郁闷的问题,用上面的语句通过(_id)去更新数据库的时候却是怎么也不能成功。

以为自己的query语句写错了,遂做了以下测试:

把Query提出来

Query q = new Query(Criteria.where("_id").is("123456.....")));

通过 findone方法测试

mongoTemplate.findOne(q,Person.class);

能够返回结果,通过

mongoTemplate.updateFirst(q,new Update().set("name","miller_cn"));

测试不通过。

我就纳闷了,相同的Query语句,却又一个能通过另外的却不行。后来又试了

Query q1 = new Query(Criteria.where("id").is("123456.....")));

结果同上。

经过了一番搜索

在http://forum.springsource.org/showthread.php?107358-Id-bug-in-where-criteria-Spring-Data-MongoDB-1.0.0.M2看到了和我遇到一样问题的兄弟,看了看他遇到的问题,下面有人回答 :it's a bug.我晕,这不麻烦了,依据id更新数据可是经常用的啊

唉,继续看,发现在这里有个leewill老兄给出了解决办法

Query q = query(where("_id").is(new ObjectId(“id”)));

http://forum.springsource.org/showthread.php?108176-mongoTemplate-update-by-ID-not-work&p=358657

依照他写的改代码,发现不行 我的new Query()里面不能跟静态的where方法,遂这个问题变成了 Query(where)的问题了,查看spring-data的文档 解决了

引入

import static org.springframework.data.document.mongodb.query.Criteria.where;

这个包

到此 问题解决

呵呵  记录一下 希望能给大家使用spring data mongo的时候提供一点帮助

我用的是M2版本

感谢leewill 老兄

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值