Spring 启动 - MongoDB - 继承
Spring Boot - MongoDB - Inheritance
我 运行 对继承和 mongodbrepositories 感到奇怪。
我有以下内容:
`
@Document
public class Base {
public String fieldA;
}
public class Derived extends Base {
public String fieldB;
}
public interface DerivedRepository extends MongoRepository<Base, String> {
List<Derived> findByFieldA(String fieldA);
}
`
插入时我得到
Inserting DBObject containing fields: [_class, _id, fieldA, fieldB ]
in collection: base
当我在存储库上执行 findByFieldA('some value') 时,我得到以下信息:
find using query: { "fieldA" : "some value" } fields: null for class:
class Derived in collection: derived
知道这里发生了什么吗?我该如何解决这个问题,要么将其保存到正确的派生集合中,要么通过从基础集合中查询。
此致,
首先,我会将 Derived
class 作为文档,因为父级将在许多实现之间共享。
public class Base {
public String fieldA;
}
@Document
public class Derived extends Base {
public String fieldB;
@Override
public String toString() {
return "{fieldA: " + getFieldA() + ", fieldB: " + fieldB + "}";
}
}
其次,将文档类型(class标记为@Document)的存储库规范更改为:
public interface DerivedRepository extends MongoRepository<Derived, String> {
List<Derived> findByFieldA(String fieldA);
List<Derived> findByFieldB(String fieldB);
}
我添加了额外的方法findByFieldB(String fieldB)
来解释更多。
进行这些更改后,您应该可以使用 fieldA
或 fieldB
进行查询,如下所示:
public class SpringBootMongoApplication {
@Autowired
private DerivedRepository derivedRepository;
public void testMethod() throws Exception {
Derived derived1 = new Derived();
derived1.setFieldB("fieldB1");
derived1.setFieldA("fieldA1");
Derived derived2 = new Derived();
derived2.setFieldB("fieldB2");
derived2.setFieldA("fieldA2");
this.derivedRepository.save(Arrays.asList(derived1, derived2));
List<Derived> deriveds = this.derivedRepository.findByFieldA("fieldA1");
System.out.println(deriveds);
List<Derived> deriveds1 = this.derivedRepository.findByFieldB("fieldB2");
System.out.println(deriveds1);
}
}
输出应该是:
[{fieldA: fieldA1, fieldB: fieldB1}]
[{fieldA: fieldA2, fieldB: fieldB2}]
您还可以使用 mongo 查询来验证持久化的对象及其类型,如下所示:
我创建了一个 Spring 引导示例应用程序,您可以在 Github 中找到它。
我 运行 对继承和 mongodbrepositories 感到奇怪。
我有以下内容:
`
@Document
public class Base {
public String fieldA;
}
public class Derived extends Base {
public String fieldB;
}
public interface DerivedRepository extends MongoRepository<Base, String> {
List<Derived> findByFieldA(String fieldA);
}
`
插入时我得到
Inserting DBObject containing fields: [_class, _id, fieldA, fieldB ] in collection: base
当我在存储库上执行 findByFieldA('some value') 时,我得到以下信息:
find using query: { "fieldA" : "some value" } fields: null for class: class Derived in collection: derived
知道这里发生了什么吗?我该如何解决这个问题,要么将其保存到正确的派生集合中,要么通过从基础集合中查询。
此致,
首先,我会将 Derived
class 作为文档,因为父级将在许多实现之间共享。
public class Base {
public String fieldA;
}
@Document
public class Derived extends Base {
public String fieldB;
@Override
public String toString() {
return "{fieldA: " + getFieldA() + ", fieldB: " + fieldB + "}";
}
}
其次,将文档类型(class标记为@Document)的存储库规范更改为:
public interface DerivedRepository extends MongoRepository<Derived, String> {
List<Derived> findByFieldA(String fieldA);
List<Derived> findByFieldB(String fieldB);
}
我添加了额外的方法findByFieldB(String fieldB)
来解释更多。
进行这些更改后,您应该可以使用 fieldA
或 fieldB
进行查询,如下所示:
public class SpringBootMongoApplication {
@Autowired
private DerivedRepository derivedRepository;
public void testMethod() throws Exception {
Derived derived1 = new Derived();
derived1.setFieldB("fieldB1");
derived1.setFieldA("fieldA1");
Derived derived2 = new Derived();
derived2.setFieldB("fieldB2");
derived2.setFieldA("fieldA2");
this.derivedRepository.save(Arrays.asList(derived1, derived2));
List<Derived> deriveds = this.derivedRepository.findByFieldA("fieldA1");
System.out.println(deriveds);
List<Derived> deriveds1 = this.derivedRepository.findByFieldB("fieldB2");
System.out.println(deriveds1);
}
}
输出应该是:
[{fieldA: fieldA1, fieldB: fieldB1}]
[{fieldA: fieldA2, fieldB: fieldB2}]
您还可以使用 mongo 查询来验证持久化的对象及其类型,如下所示:
我创建了一个 Spring 引导示例应用程序,您可以在 Github 中找到它。