我正在尝试将Spring Data REST与给定的SQL模式一起使用,该模式对关联表(交集表或多对多解析表)使用JPA @IdClass注释。这些映射实体无法正确序列化。
我创建了一个小项目,说明了这个问题。它是一个弹簧数据示例的分支,非常简单。它使用的是eclipselink,但我已经用Hibernate测试了它,问题是一样的。
https://github.com/otrosien/spring-data-examples/tree/idClassFailureWithSerializable
设置: 2个实体:客户和关系,2个存储库:CustomerRepository,RelationshipRepository,都扩展了CrudRepository
Customer生成了Id,firstname,lastname为String。 关系有IdClass" RelationshipID"和customer1,customer2作为复合主键,两者都在Customer上有外键。加上关系字符串。
基本集成测试显示实体按预期工作。
Customer dave = customers.save(new Customer("Dave", "Matthews"));
Customer jack = customers.save(new Customer("Jack", "Johnson"));
assertThat(customers.findOne(dave.getId()), is(dave));
assertThat(customers.findOne(jack.getId()), is(jack));
Relationship rel = relationships.save(new Relationship(dave, jack, "likes"));
assertThat(relationships.findOne(rel.pk()), is(rel));
到目前为止一切顺利。让我们现在通过REST API尝试这个。
POST http://localhost:8080/customers
Content-Type: application/json
{
"lastname" :"Dave",
"firstname":"Matthews"
}
POST http://localhost:8080/customers
Content-Type: application/json
{
"lastname" :"Jack",
"firstname":"Johnson"
}
POST http://localhost:8080/relationships
Content-Type: application/json
{
"customer1" : "http://localhost:8080/customers/1",
"customer2" : "http://localhost:8080/customers/2",
"relation" : "likes"
}
我总是得到201 Created,这很好。但是映射实体的表示看起来很糟糕。它们似乎是序列化的对象,而不是正确的链接。
GET /relationships
200 OK
{
"_embedded" : {
"relationships" : [ {
"relation" : "likes",
"_links" : {
"self" : {
"href" : "http://localhost:8080/relationships/Customer%20%5Bid=2,%20firstname=F,%20lastname=L%5D"
},
"customer1" : {
"href" : "http://localhost:8080/relationships/Customer%20%5Bid=2,%20firstname=F,%20lastname=L%5D/customer1"
},
"customer2" : {
"href" : "http://localhost:8080/relationships/Customer%20%5Bid=2,%20firstname=F,%20lastname=L%5D/customer2"
}
}
} ]
}
}
问题:有没有人成功地将Spring Data REST与映射实体一起使用?你能发现实施中的错误吗?或者这是一个错误? (我使用spring boot 1.2.4.RELEASE with starter-data-rest和starter-data-jpa,这应该都是最新版本)
请不要改变架构的建议。我已经知道我可以通过将生成的@Id插入到Relationship中来修复它,但模式是按原样给出的。
答案 0 :(得分:0)