List<JSONObject> re = mongoTemplate .find(new Query(Criteria.where("name").is("一灰灰blog").and("age").is(120)), JSONObject.class, COLLECTION_NAME); System.out.println("after upsert return should not be null: " + re); System.out.println("------------------------------------------"); }
输出结果如下:
1 2 3
nomatch upsert return: AcknowledgedUpdateResult{matchedCount=0, modifiedCount=0, upsertedId=BsonObjectId{value=5c49b07ce6652f7e1add1ea2}} after upsert return should not be null: [{"add":["额外增加"],"name":"一灰灰blog","_id":{"counter":14491298,"date":1548333180000,"machineIdentifier":15099183,"processIdentifier":32282,"time":1548333180000,"timeSecond":1548333180,"timestamp":1548333180},"age":120}] ------------------------------------------
4. upsert,存在则更新
前面的demo是演示不存在,那么存在数据呢?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/** * 只有一条数据匹配,upsert 即表示更新 */ publicvoidupsertOneMatch(){ // 数据存在,使用更新 UpdateResult result = mongoTemplate.upsert(new Query(Criteria.where("name").is("一灰灰blog").and("age").is(120)), new Update().set("age", 100), COLLECTION_NAME); System.out.println("one match upsert return: " + result);
List<JSONObject> ans = mongoTemplate .find(new Query(Criteria.where("name").is("一灰灰blog").and("age").is(100)), JSONObject.class, COLLECTION_NAME); System.out.println("after update return should be one: " + ans); System.out.println("------------------------------------------"); }
one match upsert return: AcknowledgedUpdateResult{matchedCount=1, modifiedCount=1, upsertedId=null} after update return should be null: [{"add":["额外增加"],"name":"一灰灰blog","_id":{"counter":14491298,"date":1548333180000,"machineIdentifier":15099183,"processIdentifier":32282,"time":1548333180000,"timeSecond":1548333180,"timestamp":1548333180},"age":100}]
UpdateResult result = mongoTemplate .upsert(new Query(Criteria.where("name").is("一灰灰blog").and("age").in(Arrays.asList(28, 100))), new Update().set("age", 120), COLLECTION_NAME); System.out.println("two match upsert return: " + result);
re = mongoTemplate.find(new Query(Criteria.where("name").is("一灰灰blog").and("age").is(120)), JSONObject.class, COLLECTION_NAME); System.out.println("after upsert return size should be 1: " + re); System.out.println("------------------------------------------"); }
根据实际输出进行查看,发现只有一条数据被修改;另外一条保持不变,结果如下
1 2 3 4 5
------------------------------------------ original record: [{"name":"一灰灰blog","_id":{"counter":12472353,"date":1548333180000,"machineIdentifier":14006254,"processIdentifier":17244,"time":1548333180000,"timeSecond":1548333180,"timestamp":1548333180},"age":28,"desc":"欢迎关注一灰灰Blog"}, {"add":["额外增加"],"name":"一灰灰blog","_id":{"counter":14491298,"date":1548333180000,"machineIdentifier":15099183,"processIdentifier":32282,"time":1548333180000,"timeSecond":1548333180,"timestamp":1548333180},"age":100}] two match upsert return: AcknowledgedUpdateResult{matchedCount=1, modifiedCount=1, upsertedId=null} after upsert return size should be 1: [{"name":"一灰灰blog","_id":{"counter":12472353,"date":1548333180000,"machineIdentifier":14006254,"processIdentifier":17244,"time":1548333180000,"timeSecond":1548333180,"timestamp":1548333180},"age":120,"desc":"欢迎关注一灰灰Blog"}] ------------------------------------------
Be the first person to leave a comment!