使用 JPA 使用外键加入另一个 table 的列
Join column from another table with Foreign Key using JPA
我是 JPA 的新手,正在尝试了解是否有办法创建一个 Entity
,其中一列来自另一列 table,由外键链接。例如,考虑以下 tables:
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
的“工作”table 创建一个 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
可以完成您正在寻找的行为。
I was looking into @JoinColumn but was not seeing the result I wanted since the foreign key is a different column in my Entity
示例:
@Entity
@Table(name = "jobs")
public class KronosFileEntity {
@Id
@Column(name = "id")
private Long id;
@ManyToOne
@JoinColumn(name = "user_id", referencedColumn = "id")
private User user;
}
然后您可以像job.getUser().getEmail()
一样访问电子邮件
如果有帮助,或者添加一个方便的方法
public String getUserEmail() {
return user.getEmail();
}
然后
job.getUserEmail()
我是 JPA 的新手,正在尝试了解是否有办法创建一个 Entity
,其中一列来自另一列 table,由外键链接。例如,考虑以下 tables:
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
的“工作”table 创建一个 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
可以完成您正在寻找的行为。
I was looking into @JoinColumn but was not seeing the result I wanted since the foreign key is a different column in my Entity
示例:
@Entity
@Table(name = "jobs")
public class KronosFileEntity {
@Id
@Column(name = "id")
private Long id;
@ManyToOne
@JoinColumn(name = "user_id", referencedColumn = "id")
private User user;
}
然后您可以像job.getUser().getEmail()
一样访问电子邮件
如果有帮助,或者添加一个方便的方法
public String getUserEmail() {
return user.getEmail();
}
然后
job.getUserEmail()