繁体   English   中英

使用 JPA 使用外键连接来自另一个表的列

[英]Join column from another table with Foreign Key using JPA

我是 JPA 的新手,并试图了解是否有办法创建一个Entity ,其中一列来自另一个由外键链接的表。 例如,考虑下表:

CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `email` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
);

CREATE TABLE `jobs` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `user_id` int(11),
  PRIMARY KEY (`id`),
  CONSTRAINT `fk_jobs_users` FOREIGN KEY (`user_id`) REFERENCES `users` (`id`)
);

现在我想为将包含user.email的“工作”表创建一个Entity 我知道我可以做类似的事情

@Entity
@Table(name = "jobs")
public class JobEntity {

    @Id
    @Column(name = "id")
    private Long id;

    @Column(name = "user_id")
    private Long userId;

    @Formula("(select user.email FROM user WHERE user.id = user_id)")
    private String userEmail;

但我觉得有一种方法可以更好地利用外键关系,但我不确定如何。 我正在查看@JoinColumn但没有看到我想要的结果,因为外键是我的Entity中的不同列。 有没有比使用@Forula更好的方法来做到这一点?

我真的不明白这一点。 我确定@JoinColumn可以完成您正在寻找的行为。

我正在查看 @JoinColumn 但没有看到我想要的结果,因为外键是我实体中的不同列

例子:

@Entity
@Table(name = "jobs")
public class KronosFileEntity {

    @Id
    @Column(name = "id")
    private Long id;

    @ManyToOne
    @JoinColumn(name = "user_id", referencedColumn = "id")
    private User user;
}

然后你可以访问 email 像job.getUser().getEmail()
或者添加一个方便的方法,如果有帮助的话

public String getUserEmail() {
   return user.getEmail();
}

然后job.getUserEmail()

暂无
暂无

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

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