0

我正在评估 Spring Data 对 Couchbase 的支持,并且遇到了以下问题。考虑以下伪代码示例,其中我有两个 POJO 类,以及为每个定义和实例化的存储库:

public class Foo
{
    @Id
    private String  _id;

    @Version
    private Long    _rev;

    // .. Other data and members.
}

public class Bar
{
    @Id
    private String  _id;

    @Version
    private Long    _rev;

    // .. Other data and members.
}


//
// Repositories
//

@Repository
public interface FooRepository extends CrudRepository<Foo, String> {
}

@Repository
public interface BarRepository extends CrudRepository<Bar, String> {
}

两个存储库都使用相同的 Couchbase 存储桶。下一个:

// Create a new Foo object and save it.
Foo f = new Foo( "id_1" );
fooRepository.save( f );

// Now, try fetching a Bar object using the ID of a Foo object (?)
Bar b = barRepository.findOne( "id_1" );

这会导致返回 Bar 对象,但未正确初始化 - 不会引发异常。问题是,为什么在这种情况下没有指示错误?当请求的类型与持久类型不匹配时,引发异常似乎并不难。我错过了什么吗?

FWIW,当我通过管理控制台查看 Couchbase 中的原始文档时,我观察到每个文档都包含一个“_class”属性,大概可用于识别用于表示数据的类,并检测此类不匹配。

4

1 回答 1

0

这里的问题是,文档(JSON 序列化实体)与 id(字段)关联存储@Id在与其他实体相同的存储桶上,这会产生一种歧义,Entity1用 id保存,将用 id1覆盖。Entity21

应用程序端的解决方案是存储具有不同键的实体,在Entity1带有 id的情况下,1例如:1-Entity1作为键。

也许您可以使用与此类似的方法来解决问题:

public Entity1 {

    private static final String ENTITY_NAME = "ENTITY1";

    @Id
    private String key;

    public void setKey(String key) {
        this.key = key;
    }

    public String getKey(String key) {
        return this.key;
    }

    public void setId(String id) {
        this.key = ENTITY_NAME + ":" + id;
    }

    public String getId() {
        if (null == this.key) 
            return null;
        return this.key.substring(ENTITY_NAME.length()+1);
    }

}
于 2014-08-03T09:59:57.447 回答