- 1、本文档共9页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Hibernate多对多Could not batch update错误解答
本例描述:
(1).有学生和老师两个对象,他们是多对多的关系。
(2).本例有如下几个文件:
Teacher.java(老师bean) Student.java(学生bean) Teacher.hbm.xml(老师映射文件) Student.hbm.xml(学生映射文件) hibernate.cfg.xml (映射文件配置文件) Many2Many.java(测试文件) 文件清单后面给出
(3).在做测试时,发生如下错误:
主要的两句错误信息:
Could not execute JDBC batch update
Caused by: java.sql.BatchUpdateException: Duplicate entry 2-2 for key PRIMARY
解答如下
我们在测试的过程中有如下的几行代码:
teacher1.setStudents(students);
teacher2.setStudents(students);
student1.setTeachers(teachers);
student2.setTeachers(teachers);
很容易理解,我们将两个学生所在的集合set到teacher1里面,也就实现了一个老师对应两个学生,下面的一句就是teacher2对应两个学生。
第三句是将两个老师所在的集合teachers集合set到student1里面,也就实现了一个学生对应两个老师,第四句同理。
错误原因:前两句和后两句实现的插入效果是相同的,所以导致了中间的关联表里面插入重复主键,从而导致了错误。
解决办法:在Student.hbm.xml(学生映射文件)或者Teacher.hbm.xml(老师映射文件)的set标签里面加入属性反转代码:inverse=”true”
本例的文件清单如下:
teacher.java
package cn.itcast.domain;
import java.util.Set;
public class Teacher {
private int id;
private String name;
private SetStudent students;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
= name;
}
public SetStudent getStudents() {
return students;
}
public void setStudents(SetStudent students) {
this.students = students;
}
}
Student.java
package cn.itcast.domain;
import java.util.Set;
public class Student {
private int id;
private String name;
private SetTeacher teachers;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
= name;
}
public SetTeacher getTeachers() {
return teachers;
}
public void setTeachers(SetTeacher teachers) {
this.teachers = teachers;
}
}
teacher.hbm.xml
?xml version=1.0 encoding=UTF-8?
!DOCTYPE hibernate-mapping PUBLIC
-//Hibernate/Hibernate Mapping DTD 3.0//EN
/hibernate-mapping-3.0.dtd
hibernate-mapping package=cn.itcast.domain
class name=Teache
文档评论(0)