0

我正在尝试围绕链接到 Mysql 数据库的 EJB / JPA 创建一个小项目。我有两个表 FctData 和 RefKpiDataQuery 由外键链接。

数据:

public class FctData implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "DATA_ID")
    private Long dataId;

    ...

    @JoinColumn(name = "DATA_QUERY_REF", referencedColumnName = "KPI_DATA_QUERY_ID")
    @ManyToOne(cascade = CascadeType.ALL)
    private RefKpiDataQuery dataQueryRef;

RefKpiDataQuery :

public class RefKpiDataQuery implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Basic(optional = false)
    @Column(name = "KPI_DATA_QUERY_ID")
    private Long kpiDataQueryId;

    ...

    @OneToMany(cascade = CascadeType.ALL, mappedBy = "dataQueryRef")
    private Set<FctData> fctDataSet;

我有一个客户端,它只是试图在数据库中插入一个 FctData

RefKpiDataQuery refKpiDataQuery = new RefKpiDataQuery();
refKpiDataQuery.setKpiDataQueryId((long) 2);

FctData fctData = new FctData();
fctData.setDataQueryRef(refKpiDataQuery);

fctDataFacade.insert(fctData);

Facade 是一种 DAO。这对没有 FK 的对象非常有效。

这是我在日志中得到的错误:

Field 'DATA_QUERY_REF' doesn't have a default value {prepstmnt 7235700 INSERT INTO FCT_DATA(DATA_DATE, DATA_TIME, DATA_VALIDITY, DATA_VALUE, ISACTIVE, UPDATE_OWNER, UPDATE_TS) VALUES (?, ?, ?, ?, ?, ?, ?)

正如我们在我的插入中看到的那样,它从不谈论数据查询。有人可以解释一下我错过了什么吗?我找不到我的错误。

谢谢你的时间。干杯

4

1 回答 1

0

我终于通过删除所有

@Basic(optional = false)

也不需要添加 cascade = CascadeType.ALL

于 2013-03-26T10:49:14.040 回答