qq_35501877
2018-04-20 12:17
采纳率: 18.2%
浏览 3.9k

mongodb的ID为String类型查询时的问题

mongodb的ID为String("102a1ds0as",不是正常的数字)类型,注意不是ObjectId,在用mongoTemplate.findAll()查询时虽然ID的字符串是一模一样,但只要mongodb的ID为string类型就是查询不出来,ObjectId类型的都可以,请问怎么处理

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • 湮顾千古 2018-04-21 03:39
    已采纳

    你可以试试我这样的方法查询

      public static void main(String[] args) {
            //1. 连接到mongodb服务
            MongoClient mongoClient = new MongoClient("localhost", 27017);
    
            //2. 连接数据库,你需要指定数据库名称,如果指定的数据库不存在,mongo会自动创建数据库
            MongoDatabase db = mongoClient.getDatabase("primton");//database
            System.out.println("MongoDB连接成功");
    
            //3. 获得集合users
            MongoCollection<Document> collection = db.getCollection("users");//table
    
    
            //5. 添加查询条件
            Document find = new Document("sex", "男");
    
    
            //4. 遍历集合users
            FindIterable<Document> documents = collection.find(find);//rows
            MongoCursor<Document> mongoCursor = documents.iterator();
            while (mongoCursor.hasNext()) {
                Document document = mongoCursor.next();
                System.out.print(document.get("_id"));
                System.out.print("," + document.get("userName"));
                System.out.print("," + document.get("userPwd"));
                System.out.print("," + document.get("sex"));
                System.out.print("," + document.get("remark"));
                System.out.print("," + document.get("age"));
                System.out.println("22222222222222");
            }
            System.out.println("ok");
    
        }
    
    点赞 打赏 评论
  • qq_35501877 2018-04-20 12:17

    为什么我的问题总是不见

    点赞 打赏 评论
  • blownewbee 2018-04-20 15:42

    ID需要用ObjectId,目测你用String只是希望建立唯一性字段,这个没有必要作为ID。

    点赞 打赏 评论
  • qq_30776233 2018-04-21 07:49

    把原来的字符串给程 "ObjectId(" + str + ")"试试

    点赞 打赏 评论
  • lkm112 2020-06-11 10:06

    同求,现在查明原因是mongoTemplate内部自动将符合自动生成规则的String类型的id转成了ObjectId类型,还没想到什么解决方案。

            if (id instanceof String) {
                return ObjectId.isValid(id.toString()) ? conversionService.convert(id, ObjectId.class) : id;
            }
    
    点赞 打赏 评论

相关推荐 更多相似问题