Struts2 と Hibernate で動作する多くのテーブル リレーションシップを持つ大規模なアプリケーションを取得する際に問題が発生しているため、それを理解するためにはるかに小規模な例を作成することにしましたが、それも機能しません。私の主な問題は、遅延インスタンス化セットが関係している場合、2 つをまったく連携させることができないことです。遅延データをロードする場合としない場合で動作させる方法を見つけようとしていますが、この場合は遅延データをロードしており、「java.lang.StackOverflowError」が発生しています。2 つのエントリを持つ「Departments」と 3 つのエントリを持つ「Employees」という 2 つのテーブルがあります。Struts2 の「xslt」結果タイプを使用しています。次に、2 つの永続性クラスを示します。
部門:
package com.test.model;
// Generated Apr 7, 2012 7:10:28 PM by Hibernate Tools 3.4.0.CR1
import java.util.HashSet;
import java.util.Set;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import static javax.persistence.GenerationType.IDENTITY;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import javax.persistence.Table;
/**
* Departments generated by hbm2java
*/
@Entity
@Table(name="Departments"
,catalog="test"
)
public class Departments implements java.io.Serializable {
private Integer id;
private String name;
private Set<Employees> employeeses = new HashSet(0);
public Departments() {
}
public Departments(String name) {
this.name = name;
}
public Departments(String name, Set employeeses) {
this.name = name;
this.employeeses = employeeses;
}
@Id @GeneratedValue(strategy=IDENTITY)
@Column(name="Id", unique=true, nullable=false)
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
@Column(name="Name", nullable=false)
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
@OneToMany(fetch=FetchType.LAZY, mappedBy="departments")
public Set<Employees> getEmployeeses() {
return this.employeeses;
}
public void setEmployeeses(Set employeeses) {
this.employeeses = employeeses;
}
}
従業員:
package com.test.model;
// Generated Apr 7, 2012 7:10:28 PM by Hibernate Tools 3.4.0.CR1
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import static javax.persistence.GenerationType.IDENTITY;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
/**
* Employees generated by hbm2java
*/
@Entity
@Table(name="Employees"
,catalog="test"
)
public class Employees implements java.io.Serializable {
private Integer id;
private Departments departments;
private String firstName;
private String lastName;
public Employees() {
}
public Employees(Departments departments, String firstName, String lastName) {
this.departments = departments;
this.firstName = firstName;
this.lastName = lastName;
}
@Id @GeneratedValue(strategy=IDENTITY)
@Column(name="Id", unique=true, nullable=false)
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="DepartmentsId", nullable=false)
public Departments getDepartments() {
return this.departments;
}
public void setDepartments(Departments departments) {
this.departments = departments;
}
@Column(name="FirstName", nullable=false)
public String getFirstName() {
return this.firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
@Column(name="LastName", nullable=false)
public String getLastName() {
return this.lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
}
DepartmentsManager クラスで使用している HQL クエリは、「from Departments d left join fetch d.employeeses」です。
エラーのスタックトレースは次のとおりです。
org.apache.commons.logging.LogFactory.getContextClassLoaderInternal(LogFactory.java:859) の java.security.AccessController.doPrivileged(Native Method) でのスレッド "http-bio-8080-exec-4" java.lang.StackOverflowError の例外org.apache.commons.logging.LogFactory.getFactory(LogFactory.java:423) で org.apache.commons.logging.LogFactory.getLog(LogFactory.java:685) で com.opensymphony.xwork2.util.logging.commons でcom.opensymphony.xwork2.util.logging.LoggerFactory.getLogger(LoggerFactory.java:42) の .CommonsLoggerFactory.getLoggerImpl(CommonsLoggerFactory.java:29) 85) org.apache.struts2.views.xslt.AbstractAdapterElement.(AbstractAdapterElement.java:41) で org.apache.struts2.views.xslt.BeanAdapter.(BeanAdapter.java:73) で sun.reflect.GeneratedConstructorAccessor14.newInstance (未知のソース) で sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) で java.lang.reflect.Constructor.newInstance(Constructor.java:525) で) org.apache.struts2.views.xslt.AdapterFactory.constructAdapterInstance(AdapterFactory.java: 209) org.apache.struts2.views.xslt.AdapterFactory.adaptNode(AdapterFactory.java:159) で org.apache.struts2.views.xslt.BeanAdapter.buildChildAdapters(BeanAdapter.java:135) で org.apache.struts2 org.apache.struts2.views.xslt.AbstractAdapterNode の .views.xslt.AbstractAdapterNode.getChildAdapters(AbstractAdapterNode.java:128)。org.apache.struts2.views.xslt.BeanAdapter.getChildNodes(BeanAdapter.java:88) の getChildNodes(AbstractAdapterNode.java:186) org.apache.struts2.views.xslt.AbstractAdapterNode.getFirstChild(AbstractAdapterNode.java:194) のcom.sun.org.apache.xalan.internal.xsltc.trax.DOM2SAX.parse(DOM2SAX.java:300) で com.sun.org.apache.xalan.internal.xsltc.trax.DOM2SAX.parse(DOM2SAX. java:302)...[この行はうんざりするほど繰り返されます]
誰かが私を正しい方向に向けてくれませんか?
ありがとう!