java - 莫菲亚错误: invalid hexadecimal representation of an ObjectId

标签 java mongodb morphia

我正在尝试学习 MongoDB 和 Morphia,并且我已经用 Java 创建了一个示例应用程序。 但是在执行聚合时,我收到“ObjectId 的十六进制表示无效”错误。

Morphia版本为1.3.2

实体:Address.java

@Entity
public class Address {

    @Id
    @Property("id")
    protected ObjectId id;

    private String street;

    private String building;

    private String pin;
}

示例文档:

{
    "_id" : ObjectId("58fcb704c1d24e05ce5851cb"),
    "building" : "SGV",
    "street" : "Galaxy Heights",
    "pin" : "411017"
}

AddressDAO.java:

public class AddressDAO extends BasicDAO<Address, ObjectId>{

    public AddressDAO(Class<Address> entityClass, Datastore ds) {
        super(entityClass, ds);
    } 

    public List<Address> getByGroupedData(String pin) {

        Query<Address> query = createQuery().field("pin").equal(pin);
        Iterator<Address> pipeline = getDatastore().createAggregation(Address.class)
                .match(query)
                .group(Group.id(Group.grouping("building"))).out(Address.class);


        while(pipeline.hasNext()) {
            System.out.println(pipeline.next());
        }

        return null;
    }
}

在 AddressDAO.java 中调用“pipeline.next()”时,出现异常:

java.lang.IllegalArgumentException: invalid hexadecimal representation of an ObjectId: [{ "building" : "Galaxy Heights"}]
    at org.bson.types.ObjectId.parseHexString(ObjectId.java:550)
    at org.bson.types.ObjectId.<init>(ObjectId.java:240)
    at org.mongodb.morphia.converters.ObjectIdConverter.decode(ObjectIdConverter.java:32)
    at org.mongodb.morphia.converters.Converters.fromDBObject(Converters.java:124)
    at org.mongodb.morphia.mapping.ValueMapper.fromDBObject(ValueMapper.java:20)
    at org.mongodb.morphia.mapping.Mapper.readMappedField(Mapper.java:844)
    at org.mongodb.morphia.mapping.Mapper.fromDb(Mapper.java:282)
    at org.mongodb.morphia.mapping.Mapper.fromDBObject(Mapper.java:193)

知道我在这里缺少什么吗?

最佳答案

我认为问题出在 $out 阶段。它使用 _id 字段创建新集合作为 building 值。

现在,当您尝试将其映射回将 _id 定义为对象 ID 的 Address 对象时,会导致错误。

因此,解决方法是使用 $projection 抑制最终响应中的 _id 字段,以便 $out 阶段创建一个新的对象 ID。

尝试这样的事情。

Iterator<Address> pipeline = getDatastore().createAggregation(Address.class)
                .match(query)
                .group(Group.id(Group.grouping("building")))
                .project(Projection.projection("_id").suppress(), Projection.projection("building", "$_id"))
                .out(Address.class);

旁注:您可能应该映射到新集合的新 pojo 对象。

关于java - 莫菲亚错误: invalid hexadecimal representation of an ObjectId,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43611549/

相关文章:

java - 访问 <#list> 中对象的属性

java - httpClient:如何检查连接是否已被服务器端关闭

php - 具有匹配和范围的redis数据存储

java - @Reference 字段上的 Morphia 点符号查询

java - 用于使用 MongoDB 进行 POJO 映射的最佳 Java 库

java - Morphia 在插入具有预定义 ID 的对象时停止

java - SNIHostName 的 NoClassDefFoundError 异常

java - 错误: Could not find or load main class ExcelReadWrite

mongoid - MongoDB 查询一个数组以获得精确的元素匹配,但可能是乱序的

MongoDB 在聚合管道中使用 $addToSet 避免重复