繁体   English   中英

java中只返回指定字段和_id字段

[英]Return the Specified Fields and the _id Field Only in java

更新:Spuggiehawk 在他的回答中建议修复include关键字问题,并建议另一种方法来获取_id而非projections 但是,我仍然无法从编辑用户详细信息的服务类中调用此方法,我必须承认我的知识有限以使其正确。

@Override
public User get(Object userId) {

    FindIterable<User> userTbl = database.getCollection("User", User.class).find();

User user = new User();

for (User doc : userTbl) {
    
    String oid = doc.getId().toHexString();

    System.out.println("_id = " + oid); 
        
        return user;
    }

    return null;
}

在服务类

public void editUser() {
    
    String userId = request.getParameter("id");
    
    User user = userDAO.get(userId);
    
    System.out.println(user.getFullName());     
}

如果您只需要对象 ID,则不需要使用投影。 您想要获得的语法(在循环中)是:

    FindIterable<Document> userTbl = db.getCollection("User").find();
    for (Document doc: userTbl2)
    {
        String id = doc.getObjectId("_id").toString();
        System.out.println("_id = " + id);
    }

使用该 id 值执行您需要的操作。

就您对 include 的使用而言,如果您确实发现需要它的情况,那么您需要静态导入。 如果您将鼠标悬停在关键字上,Eclipse 应该为您提供选项:

Eclipse 中的静态导入

如果 Eclipse 没有显示,您可能需要在 Eclipse 配置中的 Window -> Preferences -> Java -> Editor -> Content Assist -> Favorites 下添加引用:

Eclipse 静态导入包

重要的部分是在你的代码的顶部,它应该包括:

import static com.mongodb.client.model.Projections.include;

你会发现这对你的过滤器也很有用,例如。

Bson filter = eq("email", "email.com");
db.getCollection("User").find(filter);

最后,如果您只想获取 find() 中的第一条匹配记录,请使用:

Document = db.getCollection("User").find(filter).first();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM