0 امتیاز
قبل در برنامه نویسی توسط (1.1هزار امتیاز)

کاربرد انوتیشن PrimaryKeyJoinColumn در JPA چیست؟

1 پاسخ

+1 امتیاز
قبل توسط (140 امتیاز)
انتخاب شده قبل توسط
 
بهترین پاسخ

توسط  PrimaryKeyJoinColumn@  میتوان از primary key id یک جدول استفاده کرد به عنوان یک foreign key برای join زدن به یک جدول دیگر و برای رابطه OneToOne@ استفاده کرد. به عنوان مثال : 

<<     Biography class //

import javax.persistence.*;  
  
@Entity  
@Table(name="biographies")  
public class Biography {  
      
    @Id  
    @Column(name="author_id")  
    private Integer authorId;  
      
    private String information;  
  
    public Integer getAuthorId() {  
        return authorId;  
    }  
  
    public void setAuthorId(Integer authorId) {  
        this.authorId = authorId;  
    }  
  
    public String getInformation() {  
        return information;  
    }  
  
    public void setInformation(String information) {  
        this.information = information;  
    }  
      
}  

>>

 <<    Author class //

import javax.persistence.*; 
 
@Entity 
@Table(name="authors") 
public class Author { 
 
    @Id 
    @GeneratedValue 
    private Integer id; 
     
    private String name; 
     
    @OneToOne(cascade=CascadeType.ALL) 
    @PrimaryKeyJoinColumn 
    private Biography biography; 
 
    public Integer getId() { 
        return id; 
    } 
 
    public void setId(Integer id) { 
        this.id = id; 
    } 
 
    public String getName() { 
        return name; 
    } 
 
    public void setName(String name) { 
        this.name = name; 
    } 
 
    public Biography getBiography() { 
        return biography; 
    } 
 
    public void setBiography(Biography biography) { 
        this.biography = biography; 
    } 
     
}

حالا نحوه استفاده در کد :


public static void main(String[] args) {  
  
        SessionFactory sessionFactory = HibernateUtil.getSessionFactory();  
        Session session = sessionFactory.openSession();  
        session.beginTransaction();  
          
        Author author = new Author();  
        author.setName("full name");  
          
        session.persist(author);  
          
        Biography biography = new Biography();  
        biography.setInformation("some information. ......");  
        biography.setAuthorId(author.getId());  
          
        author.setBiography(biography);  
          
        session.save(author);  
          
        session.getTransaction().commit();  
          
        session.close();  
  
    }  

 

سوالات مشابه

0 امتیاز
1 پاسخ 466 بازدید
+1 امتیاز
1 پاسخ 1.1هزار بازدید
سوال شده 5 سال قبل در برنامه نویسی توسط masoud shahhosseini_ (45 امتیاز)
+1 امتیاز
1 پاسخ 396 بازدید
سوال شده 6 سال قبل در برنامه نویسی توسط یوری (426 امتیاز)
0 امتیاز
3 پاسخ 876 بازدید
سوال شده 6 سال قبل در برنامه نویسی توسط یوری (426 امتیاز)
+1 امتیاز
1 پاسخ 597 بازدید
0 امتیاز
0 پاسخ 2.8هزار بازدید
0 امتیاز
0 پاسخ 969 بازدید
+1 امتیاز
1 پاسخ 752 بازدید
0 امتیاز
1 پاسخ 506 بازدید
سوال شده 8 سال قبل در برنامه نویسی توسط Saeed Zarinfam (1.1هزار امتیاز)
0 امتیاز
1 پاسخ 716 بازدید
...