- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下结构:表“parents”和“children”,由parents.id = Children.parent_id绑定(bind)
应用程序将这些表中的数据读取到以下类的对象中:
public class Parent {
private int id;
private Map<String, String> children;
....
}
然后应用程序更改其中的数据。我需要做的是将更改应用于现有记录。我不允许更改父类或数据库结构。我尝试通过以下方式使用 jpa 存储库来做到这一点:
我的实体
@Repository
public interface ParentsDao extends JpaRepository<ParentEntity, Integer> {
}
@Entity
@Table(name = "parents")
public class ParentEntity {
@Id
@GeneratedValue
@Column(name = "id", updatable = false, insertable = false)
private Integer id;
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER, orphanRemoval = true)
@JoinColumn(name="parent_id")
private Set<ChildEntity> children;
...
}
@Entity
@Table(name = "children")
public class ChildEntity {
@Id
@GeneratedValue
@Column(name = "id", updatable = false, insertable = false)
private Integer id;
@ManyToOne
@JoinColumn(name="parent_id", updatable = false)
private ScheduledReportsEntity scheduledReport;
@Column(name = "child_name")
private String name;
@Column(name = "child_value")
private String value;
...
}
以下是我的服务,其中 action() 启动了整个过程:将 Parent 转换为 ParentEntity 并保存它
public class ParentServiceImpl {
@Autowired
ParentsDao parentsDao;
public
void action(Parent parent) {
ParentEntity entity = convert(parent); // moving data from Parent to ParentEntity object
parentsDao.save(entity); //here I receive exception
}
private ParentEntity convert(Parent parent) {
Set<ChildEntity> children = new HashSet<ChildEntity>();
for(Map.Entry<String, String> entry : simpleObj.getChildren().entrySet()){
ChildEntity childEntity = new ChildEntity();
childEntity.setName(entry.getKey());
childEntity.setValue(entry.getValue());
children.add(entity);
}
ParentEntity entity = new ParentEntity();
entity.setId(parent.getId());
entity.setChildren(children);
return entity;
}
}
但我收到以下错误:
com.app.impl.ParentServiceImpl: org.springframework.dao.DataIntegrityViolationException:
could not insert: [com.app.entities.ChildEntity];
SQL [insert into scheduled_report_params (child_name, child_value, parent_id) values (?, ?, ?)];
constraint [null];
nested exception is org.hibernate.exception.ConstraintViolationException: could not insert: [com.app.entities.ChildEntity]
我有两个问题:1. 我认为这与 child 身份缺失有关,对吗?2.如果原因是缺少id,那么有什么办法可以以某种方式绕过它并通过其他字段提供保存?将不胜感激任何建议。谢谢
最佳答案
您遇到设计问题。
你是对的,如果id
是子实体的主键,它必须存在于子集合中所有预先存在的(不是新的)ChildEntity
元素中ParentEntity
元素(如果您对其进行修改)。如果没有,Hibernate 将尝试插入它们。
因此您必须在两种解决方案之间进行选择:
在 ChildEntity
中使用生成的主键,并找到一种方法将其保留在您的应用程序中。例如,您可以使用 ParentEntity
作为真实模型类,而 Parent
是其上的 View :
class Parent {
private ParentEntity inner;
public Parent(ParentEntity entity) {
inner = entity;
// initialize children or have getChildren to dynamically create it
// from inner.childre
...
}
...
}
使用子名称作为主键。 ChildEntity
看起来像:
@Entity
@Table(name = "children")
public class ChildEntity {
@Id
@Column(name = "child_name")
private String name;
@Column(name = "child_value")
private String value;
@ManyToOne
@JoinColumn(name="parent_id", updatable = false)
private ScheduledReportsEntity scheduledReport;
...
}
但是您不能简单地忘记应用程序中的主键。
关于java - 使用onetomany连接更新实体,而子实体中没有id,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25118892/
程序集,masm 嘿,我写了宏来打印存储在 dane1 段中的 1 字节值。 我将值除以 16,然后将提醒推送到堆栈,直到值==0。然后我弹出提醒将它们转换为 ASCII 码,并打印它们。 有人可以看
我在 Apache Geronimo 2.1.3 上有一个 Web 服务应用程序。 我正在使用 JAX-WS,使用 SOAP 1.1 注释 POJOS。 (使用 Sun JDK 1.5) 各种客户端都
我有一个数据变量,monthArray,它被多个消费者读取,并由单个定期更新程序线程定期更新数据。全部异步。 我已经考虑了这两个选项来安全地执行更新。 ArrayList tempArray
我有一组 3D 体。每个 Body 由 8 个点定义,每个点具有三个坐标。所有的物体都是立方体的或近似立方体的。我想用系统的点栅格“填充”立方体。坐标存储在简单的 data.frames 中。 我开发
我正在处理遗留代码,需要打补丁。 问题:一个古老的应用程序发送错误的 HTTP POST 请求。其中一个参数未经过 URL 编码。我知道这个参数总是排在最后而且我知道它的名字。我现在正尝试在运行在 t
我想在触摸屏幕时移动 sprite body ,但它不能发生...... -(void)ccTouchEnded:(UITouch *)touch withEvent:(UIEvent *)event
这个问题在这里已经有了答案: Can a union be initialized in the declaration? (3 个答案) 关闭 7 年前。 如果它是一个struct那么它就可以完成
我正在尝试获取生成 sigsys 信号的系统调用的地址!但我从 gcc 收到以下错误: gcc emulator.c -fms-extensions error: ‘siginfo_t’ has no
当我使用 Postman 进行 API 调用时,我收到一个 JSON 对象..这是我所期望的。 但是,当我像这样与 Guzzle 进行相同的调用时: $client = new \GuzzleHttp
在编码时,出现了差异。通常在编写简单的方法或构造函数时,我经常使用表达式体技术。但是,当我产生以下内容时: public class Sample : ISample { private r
我正在使用 LibGDX 创建一个新项目。 我想做的是,我将 tmx 文件中的主体加载到工作正常的关卡中。尸体也有一个 Sprite 。 问题是,我想让用户触摸场景中的某些 body 。当他们触摸 b
我的意图:在不使用 union 的情况下循环遍历一个结构的 30 个成员,所有成员都是字符数组类型,每个成员都存储对 itoa 的调用结果。在下面的代码中,我将结构体成员命名为a-z、A-D。在调用函
我必须将我的代码段之一从 C 转换为 java。代码如下。 union commandString{ char commndStr[20]; struct{ char
#include union NumericType { float value; int intvalue; }Values; int main() { Values.va
我在此代码中收到错误: fun num(num:Int):Int { if (num > 0){ print(num % 10) return num / 10
我是一名优秀的程序员,十分优秀!