Hibernate实现单向一对多

hibernate可以很简单的实现数据库中的各种关系

下面是一个单向一对多的例子

假设一个渣男有多个女朋友 一个简单的单向一对多的例子

 

首先需要在配置文件中配置两个pojo

        <mapping class="qdm.entity.onetomany.GarbageMan" />
        <mapping class="qdm.entity.onetomany.Girl" />

 

下面是使用注解的方式自动生成数据库中的表

@Entity
@Table(name="tb_garbageman")
public class GarbageMan {

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

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

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

  /*

    这里是一对多的配置 在“一”的一方配置多的属性 由“一”主导多方,在级联时,可以通过添加一方来级联添加多方
    @Cascade(value = CascadeType.SAVE_UPDATE)
    这里要用hibernate
  */
   @OneToMany @Cascade(value
= CascadeType.SAVE_UPDATE) @JoinColumn(name="gilrs") private List<Girl> girlList=new ArrayList<Girl>(); public GarbageMan() { } public GarbageMan(String name) { this.name=name; } public String getName() { return name; } public void setName(String name) { this.name = name; } public List<Girl> getGirlList() { return girlList; } public void setGirlList(List<Girl> girlList) { this.girlList = girlList; } }
@Entity
@Table(name="tb_girl")
public class Girl {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private int id;

    private String name;

    public Girl() {
    }

    public Girl(String name) {
        this.name = name;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

下面是测试代码

public class Test {
    public static void oneToManyTest()
    {
        Girl g1=new Girl("你好");
        Girl g2=new Girl("渣男");
        GarbageMan man=new GarbageMan("渣男");
        man.getGirlList().add(g1);
        man.getGirlList().add(g2);



        Session session= Hibernate.getSession();
        session.beginTransaction();
        session.save(man);
        session.getTransaction().commit();
    }
    public static void main(String[] argv)
    {
        oneToManyTest();
    }
}

从数据库看 我们在代码中只添加了man一个实体,但是级联添加了其他属性

posted @ 2015-12-22 16:20  Seffrui  阅读(302)  评论(0编辑  收藏  举报