JPA关系映射与总结

原创 2016年05月31日 01:27:16

1.一对一:

一篇文章对应一个栏目:

文章类中:

@OneToOne(cascade=CascadeType.MERGE)
 @JoinColumn(name="newsclass_id")
 public NewsClass getNewsClass() {
  return newsClass;
 }
 public void setNewsClass(NewsClass newsClass) {
  this.newsClass = newsClass;
 }


栏目类中:

无需配置什么


2.一对多:  查用户可以获取用户拥有的所有文章的信息

一个用户有多篇文章:

用户类中:

  private List<News> items= new ArrayList<News>();

    @OneToMany(cascade=CascadeType.ALL,fetch=FetchType.EAGER,mappedBy="user")

 public List<News> getItems() {
  return items;
 }
 public void setItems(List<News> items) {
  this.items = items;
 }


文章类中:

@OneToOne(cascade=CascadeType.MERGE)
 @JoinColumn(name = "user_id")
 public User getUser() {
  return user;
 }
 public void setUser(User user) {
  this.user = user;
 }
 


双向一对多:一个用户有多篇文章,如果在文章类这里弄成ManytoOne则,默认在设置文章的时候,新增用户。且设置用户时,id不能赋值,否则出现entity.passed to persist错误

用户类中:

private List<News> items= new ArrayList<News>();

    @OneToMany(cascade=CascadeType.ALL,fetch=FetchType.EAGER,mappedBy="user")

 public List<News> getItems() {
  return items;
 }
 public void setItems(List<News> items) {
  this.items = items;
 }

文章类中:

@ManyToOne(targetEntity=User.class,cascade={CascadeType.ALL})
 public User getUser() {
  return user;
 }
 public void setUser(User user) {
  this.user = user;
 }
 

看场景来运用:最常用就是一对一和一对多了。


事务:增

private EntityManagerFactory emf;
 
 public EntityManagerFactory getEmf() {
  return emf;
 }
 @Autowired
 public void setEmf(EntityManagerFactory emf) {
  this.emf = emf;
 }

 @Test
 public void testshiwu()throws Exception {
 EntityManager em=this.getEmf().createEntityManager();
 em.getTransaction().begin();
 try{
 for(int i=0;i<5;i++)
 {
  User user=new User();
  
  user.setEmail(i+"sdsd@qq.com");
  em.persist(user);

 
 }
 em.getTransaction().commit();
 }
 catch (Exception e) {
  em.getTransaction().rollback();   //此句可不要
 }
 em.close();
 
 }
  

事务:删:先查后删,直接set完,remove会出现Removing a detached instance 错误

@Test
 public void testremove()throws Exception {
 EntityManager em=this.getEmf().createEntityManager();
 em.getTransaction().begin();
 
 for(int i=1;i<5;i++)
 {
  User user=new User();
  user.setId(i);
  em.remove(em.merge(user));

 
 }
 em.getTransaction().commit();
 
 em.close();
 
 }


事务:改:

方法一:

@Test
 public void testupdate()throws Exception {
 EntityManager em=this.getEmf().createEntityManager();
 em.getTransaction().begin();
 
 for(int i=25;i<30;i++)
 {
  User user=new User();
  user.setId(i);
  
  user.setEmail("wwwww.com");
  em.merge(user);

 
 }
 em.getTransaction().commit();
 
 em.close();
 
 }

方法2:查到后改

@Test
 public void testupdatetwo()throws Exception {
 EntityManager em=this.getEmf().createEntityManager();
 em.getTransaction().begin();
 
 for(int i=25;i<30;i++)
 {
  
  
  User user=em.find(User.class,i);
  user.setEmail("www");
  em.flush();
 //em.merge(user);
 
 }
 em.getTransaction().commit();
 
 em.close();
 
 }
  

至此结束






JPA总结——实体关系映射(一对多@OneToMany)

注意:本文出自“阿飞”的博客 ,如果要转载本文章,请与作者联系! 并注明来源: http://blog.sina.com.cn/s/blog_49fd52cf0100scql.html 一对多...

JPA总结——实体关系映射(一对一@OneToOne)

一对一(@OneToOne) · 单向关联 # 注释@OneToOne定义如下: @Target({METHOD, FIELD}) @Retention(RUNTIME) public @inter...

JPA总结——实体关系映射(一对一@OneToOne)

原文地址:JPA总结——实体关系映射(一对一@OneToOne)作者:阿飞 注意:本文出自“阿飞”的博客 ,如果要转载本文章,请与作者联系! 并注明来源: http://blog.sina...
  • thiswj
  • thiswj
  • 2015年03月16日 18:16
  • 250

JPA总结——实体关系映射(一对多@OneToMany)

一对多模型(单向) 说明: 一个客户对应多个地址,通过客户可以获得该客户的多个地址的信息。客户和地址是一对多的关系,并且客户与地址是单向关联的关系。 映射策略 # 外键关联:两个表的关系定义...

JPA一对多映射关系解析

  • 2015年10月23日 14:08
  • 1KB
  • 下载

对Jpa中Entity关系映射中mappedBy的理解

一。mappedBy 单向关系不需要设置该属性,双向关系必须设置,避免双方都建立外键字段   数据库中1对多的关系,关联关系总是被多方维护的即外键建在多方,我们在单方对象的@OneToMany(...

JPA学习笔记(8)——映射双向一对多关联关系

双向一对多关联关系前面的博客讲的都是单向的,而本问讲的是双向的(双向一对多 = 双向多对一)什么是双向?我们来对比一下单向和双向 单向/双向 User实体类中是否有List< Order> o...

JPA学习笔记(9)——映射双向一对多关联关系

双向一对多关联关系 前面的博客讲的都是单向的,而本问讲的是双向的(双向一对多 = 双向多对一) 什么是双向? 我们来对比一下单向和双向 单向/双向 User实体类中是否有List or...

JPA关系映射

JPA一对多双向1-m:多的一方为关系维护端,关系维护端负责外键纪录的更新,关系被维护端没有权力更新外键纪录. 拥有mappedBy注解的实体类为关系被维护端,另外的实体类为关系维护端的。顾名思意,关...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JPA关系映射与总结
举报原因:
原因补充:

(最多只允许输入30个字)