进行$ set更新时不使用Spring MongoDB自定义转换器吗?

问题描述 投票:2回答:2

简单示例之前的简短摘要:

  • 插入新文档就可以了,因为它使用了我的自定义转换器
  • 更新现有文档不行,因为它不使用我的自定义转换器

我的部门:

[INFO] +- org.springframework.data:spring-data-mongodb:jar:1.0.0.RC1:compile
[INFO] | +- org.springframework:spring-beans:jar:3.1.0.RELEASE:compile
[INFO] | +- org.springframework:spring-expression:jar:3.1.0.RELEASE:compile
[INFO] | +- org.springframework.data:spring-data-commons-core:jar:1.2.0.RC1:compile
[INFO] | | \- org.springframework:spring-tx:jar:3.1.0.RELEASE:compile
[INFO] | \- org.mongodb:mongo-java-driver:jar:2.7.1:compile

这是我的班级,它是它自己的转换器

public class MyClass extends MyInterface<String> ..

这里是转换器:

public class MyClassWriteConverter implements Converter<MyClass, DBObject> {
    @Override
    public DBObject convert(MyClass myClass) {
        System.out.println("MyClass WRITE CONVERTER !");
        DBObject dbo = new BasicDBObject();
        dbo.put("title", myClass.getTitle());
        dbo.put("value", myClass.getValue());
        System.out.println("value : " + myClass.getValue());
        System.out.println("class : " + myClass.getClass().getCanonicalName());
        dbo.put("_class", myClass.getClass().getCanonicalName());
        return dbo;
    }
}
public class MyClassElementReadConverter implements Converter<DBObject, MyClass> {
    @Override
    public MyClass convert(DBObject dbObject) {
        String value = (String) dbObject.get("value");
        String title = (String) dbObject.get("title");
        return new MyClass(title, value);
    }
}

<mongo:converter>
    <bean class="kam.albert.MyClassElementReadConverter" />
</mongo:converter>
<mongo:converter>
    <bean class="kam.albert.MyClassElementWriteConverter" />
</mongo:converter>

myDomain具有List<MyClass<?>> myClasses,由于使用了自定义转换器,因此效果很好:

this.ops.save(myDomain, "myCollection");

从调试输出中可以看到:

MyClass ELEMENT WRITE CONVERTER !
value : my value
class : kam.albert.MyClass

并且具有我的db.myCollection.find()。pretty();的结果。 :

{
    myClasses : [
        {
             "title" : "my title",
             "value" : "my value",
             "_class" : "kam.albert.MyClass"
        }
    ]
}

通过插入操作一切都还好...

但是当我对这样的现有文档进行$ set更新时:

this.ops.updateFirst(
    this.idCriteria(myClass),
    new Update()
        // set the content node
        .set(dotNotation, myClass),
        "myCollection"
);

调试输出保持不变:

MyClass ELEMENT WRITE CONVERTER !
value : my value
class : kam.albert.MyClass
(edited for clarity, the other properties omitted)
DEBUG [mongodb.core.MongoTemplate]: calling update using query: { "_id" : "81d3292e-fd75-410d-a1f9-b109b6d76194"} and update: { "$
set" : { "myClasses" : [ { "title" : "my title" , "value" : "my value"}]}] } in collection: myCollection

但是结果就像没有使用自定义转换器,没有“ _class”属性:

{
    myClasses : [
        {
             "title" : "my title",
             "value" : "my value",
        }
    ]
}

我目前的结论是:

  • 对于插入新文档,自定义转换器工作正常
  • 尽管用于更新,尽管自定义转换器似乎被调用了(调试输出在那里),但是它似乎正在使用默认的MappingMongoConverter进行真正的更新。

我想念什么吗?请分享您的想法..

spring spring-data mongodb-java
2个回答
2
投票

似乎当前版本(截至撰写本文时为1.0 GA)并未将Update对象传递到QueryMapper中,后者负责将包含的潜在复杂对象压缩为MongoDB可以本地处理的对象。在此过程中,应调用MongoConverter,这又将触发您的自定义转换器。

此问题已在the ticket you just filed中捕获,将在下一个错误修正版本(1.0.1,1.1.M1)中修复。


0
投票

您找到解决方案了吗?因为我和你有同样的问题..当我使用save或insert方法时,我的自定义转换器可以工作,但不适用于更新查询]

© www.soinside.com 2019 - 2024. All rights reserved.