Olingo/JPA 不在批量请求中存储外键
Olingo/JPA does not store foreign keys in batch requests
我基于这个GitHub repository.
用olingo2、jpa和spring-boot做了一个odata服务
我将 olingo 的版本升级到 2.0.11,并且 spring 启动到 2.3.0,正如我解释的那样 。
我尝试使用以下批处理请求负载创建一个对象:
--batch_661f-eaa8-27e8
Content-Type: multipart/mixed; boundary=changeset_cd7f-245c-cede
--changeset_cd7f-245c-cede
Content-Type: application/http
Content-Transfer-Encoding: binary
POST FormSet HTTP/1.1
sap-contextid-accept: header
Accept: application/json
Accept-Language: en-US
DataServiceVersion: 2.0
MaxDataServiceVersion: 2.0
Content-Type: application/json
Content-Length: 114
{"IconId":"IC1","Deleted":0,"Name":"mm","ValidFrom":"\/Date(1591260532000)\/","ValidTo":"\/Date(1593074937000)\/"}
--changeset_cd7f-245c-cede--
--batch_661f-eaa8-27e8--
问题是它会在数据库中创建 Form
对象,但不会像我传递的那样设置外键(即 IconId
)。这是回复:
--batch_3e32b3e0-b61d-4bb9-9c3c-4c6a22ca07a4
Content-Type: multipart/mixed; boundary=changeset_779fb130-eb85-40c4-be2c-114c210bbda0
--changeset_779fb130-eb85-40c4-be2c-114c210bbda0
Content-Type: application/http
Content-Transfer-Encoding: binary
HTTP/1.1 201 Created
DataServiceVersion: 2.0
Location: http://localhost:9090/odata.svc/FormSet(0)
Content-Type: application/json
Content-Length: 522
{"d":{"__metadata":{"id":"http://localhost:9090/odata.svc/FormSet(0)","uri":"http://localhost:9090/odata.svc/FormSet(0)","type":"me.cimply.Form"},"Deleted":0,"IconId":null,"Id":0,"Name":"mm","ValidFrom":"\/Date(1591260532000)\/","ValidTo":"\/Date(1593074937000)\/","Icon":{"__deferred":{"uri":"http://localhost:9090/odata.svc/FormSet(0)/Icon"}},"Questions":{"__deferred":{"uri":"http://localhost:9090/odata.svc/FormSet(0)/Questions"}},"Surveys":{"__deferred":{"uri":"http://localhost:9090/odata.svc/FormSet(0)/Surveys"}}}}
--changeset_779fb130-eb85-40c4-be2c-114c210bbda0--
--batch_3e32b3e0-b61d-4bb9-9c3c-4c6a22ca07a4--
可以看出响应中的IconId
为空。
这是表单的 JPA 自动生成实体:
package me.cimply.ask.odata.entities;
import java.io.Serializable;
import javax.persistence.*;
import java.sql.Timestamp;
import java.util.Set;
/**
* The persistent class for the forms database table.
*
*/
@Entity
@Table(name="forms")
@NamedQuery(name="Form.findAll", query="SELECT f FROM Form f")
public class Form implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@Column(unique=true, nullable=false)
private int id;
@Column(nullable=false)
private byte deleted;
@Column(nullable=false, length=255)
private String name;
@Column(name="valid_from", nullable=false)
private Timestamp validFrom;
@Column(name="valid_to")
private Timestamp validTo;
//bi-directional many-to-one association to Icon
@ManyToOne
@JoinColumn(name="icon_id")
private Icon icon;
public Form() {
}
public int getId() {
return this.id;
}
public void setId(int id) {
this.id = id;
}
public byte getDeleted() {
return this.deleted;
}
public void setDeleted(byte deleted) {
this.deleted = deleted;
}
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
public Timestamp getValidFrom() {
return this.validFrom;
}
public void setValidFrom(Timestamp validFrom) {
this.validFrom = validFrom;
}
public Timestamp getValidTo() {
return this.validTo;
}
public void setValidTo(Timestamp validTo) {
this.validTo = validTo;
}
public Icon getIcon() {
return this.icon;
}
public void setIcon(Icon icon) {
this.icon = icon;
}
//....
}
另一个问题是 Id 是 auto increment
而返回零,我知道如何通过设置 id 生成器策略来解决它。但是找到一种设置外键的方法很重要!
我使用了与 here 解释相同的方法并解决了问题。我们需要为 POST 和 PUT 函数自定义批处理函数。
我基于这个GitHub repository.
用olingo2、jpa和spring-boot做了一个odata服务我将 olingo 的版本升级到 2.0.11,并且 spring 启动到 2.3.0,正如我解释的那样
我尝试使用以下批处理请求负载创建一个对象:
--batch_661f-eaa8-27e8
Content-Type: multipart/mixed; boundary=changeset_cd7f-245c-cede
--changeset_cd7f-245c-cede
Content-Type: application/http
Content-Transfer-Encoding: binary
POST FormSet HTTP/1.1
sap-contextid-accept: header
Accept: application/json
Accept-Language: en-US
DataServiceVersion: 2.0
MaxDataServiceVersion: 2.0
Content-Type: application/json
Content-Length: 114
{"IconId":"IC1","Deleted":0,"Name":"mm","ValidFrom":"\/Date(1591260532000)\/","ValidTo":"\/Date(1593074937000)\/"}
--changeset_cd7f-245c-cede--
--batch_661f-eaa8-27e8--
问题是它会在数据库中创建 Form
对象,但不会像我传递的那样设置外键(即 IconId
)。这是回复:
--batch_3e32b3e0-b61d-4bb9-9c3c-4c6a22ca07a4
Content-Type: multipart/mixed; boundary=changeset_779fb130-eb85-40c4-be2c-114c210bbda0
--changeset_779fb130-eb85-40c4-be2c-114c210bbda0
Content-Type: application/http
Content-Transfer-Encoding: binary
HTTP/1.1 201 Created
DataServiceVersion: 2.0
Location: http://localhost:9090/odata.svc/FormSet(0)
Content-Type: application/json
Content-Length: 522
{"d":{"__metadata":{"id":"http://localhost:9090/odata.svc/FormSet(0)","uri":"http://localhost:9090/odata.svc/FormSet(0)","type":"me.cimply.Form"},"Deleted":0,"IconId":null,"Id":0,"Name":"mm","ValidFrom":"\/Date(1591260532000)\/","ValidTo":"\/Date(1593074937000)\/","Icon":{"__deferred":{"uri":"http://localhost:9090/odata.svc/FormSet(0)/Icon"}},"Questions":{"__deferred":{"uri":"http://localhost:9090/odata.svc/FormSet(0)/Questions"}},"Surveys":{"__deferred":{"uri":"http://localhost:9090/odata.svc/FormSet(0)/Surveys"}}}}
--changeset_779fb130-eb85-40c4-be2c-114c210bbda0--
--batch_3e32b3e0-b61d-4bb9-9c3c-4c6a22ca07a4--
可以看出响应中的IconId
为空。
这是表单的 JPA 自动生成实体:
package me.cimply.ask.odata.entities;
import java.io.Serializable;
import javax.persistence.*;
import java.sql.Timestamp;
import java.util.Set;
/**
* The persistent class for the forms database table.
*
*/
@Entity
@Table(name="forms")
@NamedQuery(name="Form.findAll", query="SELECT f FROM Form f")
public class Form implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@Column(unique=true, nullable=false)
private int id;
@Column(nullable=false)
private byte deleted;
@Column(nullable=false, length=255)
private String name;
@Column(name="valid_from", nullable=false)
private Timestamp validFrom;
@Column(name="valid_to")
private Timestamp validTo;
//bi-directional many-to-one association to Icon
@ManyToOne
@JoinColumn(name="icon_id")
private Icon icon;
public Form() {
}
public int getId() {
return this.id;
}
public void setId(int id) {
this.id = id;
}
public byte getDeleted() {
return this.deleted;
}
public void setDeleted(byte deleted) {
this.deleted = deleted;
}
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
public Timestamp getValidFrom() {
return this.validFrom;
}
public void setValidFrom(Timestamp validFrom) {
this.validFrom = validFrom;
}
public Timestamp getValidTo() {
return this.validTo;
}
public void setValidTo(Timestamp validTo) {
this.validTo = validTo;
}
public Icon getIcon() {
return this.icon;
}
public void setIcon(Icon icon) {
this.icon = icon;
}
//....
}
另一个问题是 Id 是 auto increment
而返回零,我知道如何通过设置 id 生成器策略来解决它。但是找到一种设置外键的方法很重要!
我使用了与 here 解释相同的方法并解决了问题。我们需要为 POST 和 PUT 函数自定义批处理函数。