微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用JPQL联接两个表

如何解决如何使用JPQL联接两个表

我制作了员工表和职位表。每个员工都有一个职位。我想联接两个表,但是我不知道如何编写代码

Employee.java

@Table(name = "employees")
@NamedQueries({
        @NamedQuery(name = "getAllEmployees",query = "SELECT e FROM Employee AS e ORDER BY e.emp_id DESC")
})
@Entity
public class Employee {
    @Id
    @Column(name = "emp_id",length = 8)
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer emp_id;

    @Column(name = "emp_name",length = 20,nullable = false)
    private String emp_name;

    @OnetoOne(cascade = CascadeType.ALL)
    @JoinTable(name = "position",joinColumns = {
            @JoinColumn(name = "emp_id",referencedColumnName = "emp_id") },inverseJoinColumns = {
                    @JoinColumn(name = "pos_id",referencedColumnName = "pos_id") })
    private Position pos;
    
    ~setter/getter~

Position.java

@Table(name = "position")

@Entity
public class Position {
    @Id
    @Column(name = "pos_id")
    private Integer pos_id;

    @Column(name = "pos_name",length = 30,nullable = false)
    private String pos_name;

    @OnetoOne(mappedBy = "pos")
    private Employee employee;
    
    ~setter/getter~

解决方法

Employee.java
@Entity
public class Employee {
    @Id
    @Column(name = "emp_id",length = 8)
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer emp_id;

    @Column(name = "emp_name",length = 20,nullable = false)
    private String emp_name;

    @ManyToOne
    private Position position;
Position.java
@Entity
public class Position {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private int pos_id;

    @Column(name = "pos_name",length = 16)
    private String pos_name;

    @OneToMany(mappedBy = "position")
    private List<Employee> employees;

谢谢。我可以加入两个桌子!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。