繁体   English   中英

数据库中的 toBuilder() 与 Setter

[英]toBuilder() vs Setter in database

我正在尝试以双向方式使用 OneToOne 映射将数据保存在数据库中。 我用过 toBuilder 和 setter 并在数据库中得到了不同的结果。 通过使用设置器:

        Question question = Question.builder().quest("What is Pythonn ?").answer(null).build();
        Answer answer = Answer.builder().answer("Python is language").que(question).build();
        answer.setQue(question);
        question.setAnswer(answer);
        Question question2 = Question.builder().quest("How are you ?").answer(null).build();
        Answer answer2 = Answer.builder().answer("I am fine").build();
        answer2.setQue(question2);
        question2.setAnswer(answer2);
        session.save(question);
        session.save(question2);

数据库中的结果

问题表

答案表

通过使用 toBuilder

 answer.toBuilder().que(question).build();
 question = question.toBuilder().answer(answer).build();
 answer2.toBuilder().que(question2).build();
 question2 = question.toBuilder().answer(answer2).build();

db 中的结果: question_table

answer_table

为什么在 setter 工作时 toBuilder 不工作?

您不会在 answer2 中保存对 question2 的引用。 这就是为什么答案 2 的问题列具有空值。

Answer answer2 = Answer.builder().answer("I am fine").build();
 answer2.toBuilder().que(question2).build();

并且您在问题 2 的构建器中使用问题。 这就是问题 1 有多个条目的原因。

question2 = question.toBuilder().answer(answer2).build();

至于答案为空值的第一个问题行,我不确定它来自哪里。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM