- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个要求,我必须向同一个表中的特定列添加外键约束。例如,我有一个表 PROJECT,它有一个主键列“id”和另一列“dependency_project_id”,它是引用“id”列的外键。
我更改了表格并添加了如下约束:更改表项目添加约束 FK_DEPENDENCY_PROJECT_ID 外键 (DEPENDENCY_PROJECT_ID) 引用项目 (ID);
但是,我的第二个要求是,“dependency_project_id”列在某些情况下可以为空。但是,如果我尝试在 dependency_project_id 列中插入 null,则会收到错误“ORA-02291:违反完整性约束 - 未找到父键”。
请注意,我正在使用 JPA 将数据保存到数据库中。但是,如果我直接在数据库中的 dependency_project_id 列中插入 null,则可以毫无问题地执行此操作。
这是我的实体。
package com.oracle.estimationtool.model;
import java.util.List;
import javax.json.bind.annotation.JsonbTransient;
import javax.persistence.Access;
import javax.persistence.AccessType;
import javax.persistence.Basic;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.Lob;
import javax.persistence.ManyToOne;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.Size;
@Entity(name = "Project")
@Table(name = "PROJECT")
@Access(value = AccessType.FIELD)
@SequenceGenerator(name = "ProjectSeq", sequenceName = "PROJECT_SEQ", allocationSize = 50)
@NamedQuery(name = "Project.findProject", query = "SELECT p from Project p where p.id = :id")
public class Project extends BaseEntity {
@Id
@GeneratedValue(generator = "ProjectSeq", strategy = GenerationType.SEQUENCE)
private Integer id;
@OneToMany
@JoinColumn(name = "PROJECT_ID")
private List<SolutionComponentEstimate> solutionComponentEstimates;
@Column(columnDefinition = "CLOB NULL", name = "BUSINESS_EVENTS", nullable = true)
@Lob
@Basic(optional = true)
private List<BusinessEvent>businessEvents;
@Column(nullable = true, precision = 10, scale = 4)
@Basic(optional = true)
private Double duration;
@OneToMany(cascade = CascadeType.ALL, orphanRemoval = true)
@JoinColumn(name = "PROJECT_ID")
private List<SCVersionProject> scvproject;
@Column(name = "NAME", length = 255, nullable = false)
@Basic(optional = false)
@Size(max = 255)
@NotBlank
private String name;
@Column(name = "DEPENDENCY_PROJECT_ID", nullable = true)
@Basic(optional = true)
private int dependencyProjectId;
@Column(name = "DEPENDENCY_START", nullable = true)
@Basic(optional = true)
private boolean dependencyStart;
@Column(name = "DEPENDENCY_DELTA", nullable = true)
@Basic(optional = true)
private int dependencyDelta;
@ManyToOne
@JoinColumn(name = "ROADMAP_ID")
@JsonbTransient
private Roadmap roadmap;
public Project() {
}
public Project(List<SolutionComponentEstimate> solutionComponentEstimates, List<BusinessEvent> businessEvents,
Double duration, String name) {
this.solutionComponentEstimates = solutionComponentEstimates;
this.businessEvents = businessEvents;
this.duration = duration;
this.name = name;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public List<SolutionComponentEstimate> getSolutionComponentEstimates() {
return solutionComponentEstimates;
}
public void setSolutionComponentEstimates(List<SolutionComponentEstimate> solutionComponentEstimates) {
this.solutionComponentEstimates = solutionComponentEstimates;
}
public List<BusinessEvent> getBusinessEvents() {
return businessEvents;
}
public void setBusinessEvents(List<BusinessEvent> businessEvents) {
this.businessEvents = businessEvents;
}
public Double getDuration() {
return duration;
}
public void setDuration(Double duration) {
this.duration = duration;
}
public List<SCVersionProject> getScvproject() {
return scvproject;
}
public void setScvproject(List<SCVersionProject> scvproject) {
this.scvproject = scvproject;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getDependencyProjectId() {
return dependencyProjectId;
}
public void setDependencyProjectId(int dependencyProjectId) {
this.dependencyProjectId = dependencyProjectId;
}
public boolean isDependencyStart() {
return dependencyStart;
}
public void setDependencyStart(boolean dependencyStart) {
this.dependencyStart = dependencyStart;
}
public int getDependencyDelta() {
return dependencyDelta;
}
public void setDependencyDelta(int dependencyDelta) {
this.dependencyDelta = dependencyDelta;
}
public Roadmap getRoadmap() {
return roadmap;
}
public void setRoadmap(Roadmap roadmap) {
this.roadmap = roadmap;
}
}
我是 JPA 新手。我是否缺少任何内容或有任何解决方法?非常感谢任何帮助。
最佳答案
您应该将 DEPENDENCY_PROJECT_ID 映射到 Integer 而不是 int。int 不能有空值。如果没有设置,则值为 0,因此违反约束。
关于java - ORA-02291 : integrity constraint violated - parent key not found When trying to insert null in foreign key,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60327285/
我正在查看 SQL Server 2008 的 AdventureWorks 示例数据库,我在他们的创建脚本中看到他们倾向于使用以下内容: ALTER TABLE [Production].[Prod
我目前正在使用 PostgreSQL 9.5,想知道是否有可能在 ON CONFLICT ON CONSTRAINT 语句中包含 2 个约束的名称。我的sql如下 INSERT INTO LIVE.T
使用 htmlhelpers 可以限制你的助手将绑定(bind)到什么类型 public static HtmlString DatePicker(this HtmlHelper html,
我使用的是 Symfony 2.5,我的 Model 类如下: /** * @UserAssert\UserPasswordReset */ class ResetPassword { /** *
我有 3 个 View :A、B、C。 (A 和 B 的高度相等)开始时 B 的可见性消失,C 的顶部约束是 A 的底部,因此 C 出现在 A 下方。一段时间后,我将 A 的可见性更改为消失,将 B
在 Dojo NumberTextBox 的文档中,措辞引用了“Dojo 约束语言”,甚至包括有用的 link .不幸的是,链接指向的页面仅显示 this document has been depr
在我的表中,我有一个唯一的约束。在 hibernate 中,当我添加一个违反该约束的项目时,我想捕获它,因此它将更新而不是创建一个项目。 当我没有设置 try-catch block 时 up
我正在尝试在“或”UILabel 附近添加两条 1 像素线(由 UIViews 组成)。 除了我从 Interface Builder 中的第一张图片收到警告外,一切看起来都很好并且按预期工作: Le
我已经开始学习安卓了。我正在尝试使用 Google Map API。每次我尝试启动我的应用程序时,它都会崩溃,经过调查,我在 build.gradle 文件中发现了一个通知。 Please refer
我有自定义约束: @Target({FIELD, METHOD}) @Retention(RetentionPolicy.RUNTIME) @ConstraintComposition(Composi
我正在将 Graphql 服务器与 Prisma 一起使用。但是当我尝试运行代码时出现此错误我正在使用 const { GraphQLServer } = require('graphql-yoga'
更新到 com.android.support.constraint:constraint-layout:1.1.0 之后 约束布局崩溃说: All children of constraint la
我在 Xcode 10 中工作,在尝试向我的 View 添加一些非常简单的约束时遇到了一些错误。 我有一个 UICollectionViewCell,我正在向其添加一个 UIStackView。我调整
尝试在 Laravel 上创建一个待办事项列表应用程序,但是当我尝试单击按钮创建一个新的待办事项列表时,出现此错误: SQLSTATE[23000]: Integrity constraint vio
我正在编写一个基于网格的 View ,使用以下代码动态添加 NSLayoutConstraints for (x, column) in enumerate(board) { for (y,
我正在尝试使用 Constraint composition并希望为每个复合约束定义组,如下例所示:- 复合约束 @Target({ ElementType.FIELD, Elemen
我有一些添加了外键约束的表。它们与代码生成一起使用,以在生成的存储过程中设置特定的联接。 是否可以通过在事务中调用多个删除来覆盖这些约束,特别是 C# 中的“TransactionScope”,或者绝
我需要向现有 SQL Server 表添加约束,但前提是该表尚不存在。 我使用以下 SQL 创建约束。 ALTER TABLE [Foo] ADD CONSTRAINT [FK_Foo_Bar] FO
这是我的总输出: Executing SQL script in server ERROR: Error 1215: Cannot add foreign key constraint CREATE
我正在增加 Facebook SDK 登录按钮 (FBSDKLoginButton) 的大小。 Facebook SDK 源代码向 FBSDKLoginButton 添加了一个约束,height =
我是一名优秀的程序员,十分优秀!