java - 在 db hibernate 中插入外键

标签 java mysql database hibernate foreign-keys

我有一个包含五条数据的节点数据库:

  • id(整数,PK)
  • 问题(varchar)
  • 结果(varchar)
  • left_id(int,FK)
  • right_id(int FK)

同一个表中的两个外键:

  • left_id -> ID
  • right_id -> id

这是我的 bean :

@Entity
@Table (name = "node")
public class Nodes
{
    @Id
    @GeneratedValue (strategy = GenerationType.IDENTITY)
    @Column(name="id")
    @NotNull
    private int id;

    @Column (name = "question")
    private String question;

    @Column ( name = "result")
    private String result;

    @OneToOne(fetch= FetchType.LAZY)
    @JoinColumn(name="left_id", referencedColumnName="id")
    private Nodes left;

    @OneToOne(fetch= FetchType.LAZY)
    @JoinColumn(name="right_id", referencedColumnName="id")
    private Nodes right;

我可以通过以下方式查看 left_id:

nodes.getLeftNodes().getId_node();

但是我无法在数据库中插入新数据 left/right_id

我的插入方法是

public void insert_question(String question, int left_id) throws HibernateException
    {
        try
        {
            Session session = getSession();
            Transaction tx = session.beginTransaction();

            Nodes node = new Nodes();

            node.setQuestion(question);
            node.setId_node(left_id);

            session.saveOrUpdate(node);
            tx.commit();
            session.close();
        }

问题已插入数据库,但未插入 left_id。对我来说,问题是外键(节点左或右)是一个对象,但在我的数据库中 left_id 是一个整数!

由于存在外键,如何在没有 left/right_id 整数的情况下在数据库中插入 left/right_id ?

非常感谢

最佳答案

如果我理解正确,您想要创建一个新节点,其中包含对现有左节点的引用。 left_id(我将其重命名为 leftId 以符合标准命名约定)是现有左节点的标识符。

所以这很简单:您首先需要获取对数据库中现有节点左节点的引用,创建引用此左节点的新节点,然后插入新节点:

Node leftNode = (Node) session.load(Node.class, leftId);

Node node = new Node();
node.setQuestion(question);
node.setLeft(leftNode);

session.save(node);

请注意,我还将 Nodes 重命名为 Node。此类的一个实例代表一个节点,因此没有理由将此类命名为Nodes

关于java - 在 db hibernate 中插入外键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23411064/

相关文章:

mysql - 如何防止 php Warning : mysql_fetch_assoc

java - 包含带有 Jar 文件的属性文件

java - 为什么字符串转换不是数字提升的一种类型?

java - 弄乱了我的应用程序,现在加载时崩溃了。不明白catlog中的错误

java - Freemarker:方便生成UUID

php - 优化/替代此自引用更新查询

mysql:计算每组中值的数量

MySQL插入table1更新table2,子查询还是事务?

mysql - 我应该如何解析MySQL中的--secure-file-priv?

java - 如何使用java在服务器端实现倒计时触发器?