Hibernate :Found shared references to a collection

Session session=getSessionFactory().getCurrentSession();
		Question q=(Question)session.get(Question.class, id);
	Question_Engineer qe=new Question_Engineer();
		qe.setAdminUser(q.getAdminUser());
		qe.setContent(q.getContent());
		qe.setCreatTime(DateFormat.DateToStringD());
		qe.setDepartment(q.getDepartment());
		qe.setDoUser(q.getDoUser());
		qe.setFiles(files);
		qe.setIp(q.getIp());
		qe.setModule(module);
		qe.setPhone(q.getPhone());
		qe.setQuestionId(q.getQuestionId());
		qe.setReportTime(q.getReportTime());
		qe.setResolve(q.getResolve());
		qe.setState(q.getState());
		qe.setStatus(q.getStatus());
		qe.setTitle(q.getTitle());
		qe.setUser(user);

 然后又做持久

org.hibernate.Transaction tx = session.beginTransaction();  
		try{
			//存储monitoringLog
			session.save(qe);  
			//刷新缓存
			session.flush(); 
			//提交事务
			tx.commit();   
		}catch (Exception e) {
			e.printStackTrace();
			//异常回滚
			tx.rollback();
		}finally{
			//关闭连接
			session.close();  
		}

 就在session.flush(); 抛了异常

遇到这个问题原因是:1.表之间有关联。在复制数据。

3,你用了hibernate,并在复制数据时将要复制的数据对象A的所有属性赋给了对象B。

解决方案:

将那些关联的数据也复制一遍,并更新B的那些关联对象。这些关联数据中的一个或多个为空时也必须更新B中相应的关联对象

于是:

Module module=new Module();
		List<UploadFile> files = new ArrayList<UploadFile>();
		User user=q.getUser();
		try {
			BeanUtils.copyProperties(module, q.getModule());
			BeanUtils.copyProperties(user, q.getUser());
			BeanUtils.copyProperties(files, q.getFiles());
		} catch (Exception e1) {
			// TODO Auto-generated catch block
			e1.printStackTrace();
		}

 然后set进去就不会出现该问题

猜你喜欢

转载自umbrellall1.iteye.com/blog/1246920
今日推荐