2016-11-25 145 views
0

net.sf.json.JSONException: org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role: dao.entities.CourseMaster.chapterCourseMappings, no session or session was closednet.sf.json.JSONException:org.hibernate.LazyInitializationException:無法初始化懶洋洋角色的集合

我的實體:

@Entity 
    @Table(name = "course_master") 
    public class CourseMaster implements Serializable { 

private Integer id; 
private String courseName; 
private String category; 
private Set<CourseWeightage> courseWeightages = new HashSet<CourseWeightage>(); 
private Set<ChapterCourseMapping> chapterCourseMappings = new HashSet<ChapterCourseMapping>(); 

public CourseMaster() { 
} 

public CourseMaster(String courseName, String category) { 
    this.courseName = courseName; 
    this.category = category; 
} 

public CourseMaster(String courseName, String category, 
     Set<CourseWeightage> courseWeightages, Set<ChapterCourseMapping> chapterCourseMappings) { 
    this.courseName = courseName; 
    this.category = category; 
    this.courseWeightages = courseWeightages; 
    this.chapterCourseMappings = chapterCourseMappings; 
} 

@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 = "course_name", nullable = false, length = 100) 
public String getCourseName() { 
    return this.courseName; 
} 

public void setCourseName(String courseName) { 
    this.courseName = courseName; 
} 

@Column(name = "category", nullable = false, length = 2) 
public String getCategory() { 
    return this.category; 
} 

public void setCategory(String category) { 
    this.category = category; 
} 

@OneToMany(fetch = FetchType.EAGER, mappedBy = "courseMaster") 
public Set<CourseWeightage> getCourseWeightages() { 
    return this.courseWeightages; 
} 

public void setCourseWeightages(Set<CourseWeightage> courseWeightages) { 
    this.courseWeightages = courseWeightages; 
} 


@OneToMany(fetch = FetchType.LAZY, mappedBy = "courseMaster") 
public Set<ChapterCourseMapping> getChapterCourseMappings() { 
    return this.chapterCourseMappings; 
} 

public void setChapterCourseMappings(Set<ChapterCourseMapping> chapterCourseMappings) { 
    this.chapterCourseMappings = chapterCourseMappings; 
} 
} 

控制器方法:(REST的Web服務API)

引起異常的方法中的潛在操作!

net.sf.json.JSONObject data = new net.sf.json.JSONObject(); 

    List<CourseMaster> alrCourseMasters = genericBusiness.getCourses(); 

    data.put("courselist", alrCourseMasters); 

    view = new Viewable("/test.jsp", data); 

    return Response.status(200).entity(view).build(); 

DAO方法:

public List<CourseMaster> getCourses() 
{ 
    Session session = sessionFactory.openSession(); 
    Transaction transaction = session.beginTransaction(); 
    Query query = session.createQuery("from CourseMaster"); 
    List<CourseMaster> alrCourseMasters = query.list(); 
    transaction.commit(); 
    session.flush(); 
    session.close(); 
    return alrCourseMasters; 
} 

回答

0

如果您序列化對象到字符串,你應該有渴望初始化您的相關休眠實體。

你的情況

@OneToMany(fetch = FetchType.LAZY, mappedBy = "courseMaster") 
public Set<ChapterCourseMapping> getChapterCourseMappings() { 
return this.chapterCourseMappings; 
} 

重命名爲如下

@OneToMany(fetch = FetchType.EAGER, mappedBy = "courseMaster") 
public Set<ChapterCourseMapping> getChapterCourseMappings() { 
return this.chapterCourseMappings; 
} 

同時檢查所有關聯應該是預先抓取。

或者,您可以在hibernate中使用create SQlQueries並將結果映射到某個pojo並將其轉換爲json字符串。它會起作用。

相關問題