前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >spring mvc报错,数据库查询无限死循环

spring mvc报错,数据库查询无限死循环

作者头像
二十三年蝉
发布2018-02-28 11:36:34
1.3K0
发布2018-02-28 11:36:34
举报
文章被收录于专栏:闻道于事

进行查询的陷入了无限死循环,原因是问题类中包含了回答,回答类中包含了问题,进入了无限死循环

解决方法:在回答类中的问题类属性上加注解:@JsonBackReference

问题中有回答的set集合,回答中有问题类:

问题类:

代码语言:javascript
复制
package com.wazn.learn.entity.teachclass;

import java.util.Date;
import java.util.HashSet;
import java.util.List;
import java.util.Set;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.OneToMany;
import javax.persistence.Table;

import com.wazn.learn.entity.sys.User;

/**
 * 
 * 提问表
 *
 */
@Entity
@Table(name="teach_questions")
public class Questions {
    private Integer id;//id
    private User userid;//学生id
    private TeachClass cid;//课程id
    private String question;//提问
    private Date twtime;//提问时间
    private String title;
    private Set<Answer> answer;
    
    
    
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    
    @Column(nullable=false)
    
    public String getQuestion() {
        return question;
    }
    public void setQuestion(String question) {
        this.question = question;
    }
    @ManyToOne
    @JoinColumn(name="c_id",nullable=false,insertable=true)
    public TeachClass getCid() {
        return cid;
    }
    public void setCid(TeachClass cid) {
        this.cid = cid;
    }
    @ManyToOne
    @JoinColumn(name="user_id",nullable=false,insertable=true)
    public User getUserid() {
        return userid;
    }
    public void setUserid(User userid) {
        this.userid = userid;
    }
    public Date getTwtime() {
        return twtime;
    }
    public void setTwtime(Date twtime) {
        this.twtime = twtime;
    }
    
 @OneToMany(cascade = { CascadeType.REFRESH, CascadeType.PERSIST,CascadeType.MERGE, CascadeType.REMOVE },mappedBy ="question")
    public Set<Answer> getAnswer() {
        return answer;
    }
    public void setAnswer(Set<Answer> answer) {
        this.answer = answer;
    }
    public String getTitle() {
        return title;
    }
    public void setTitle(String title) {
        this.title = title;
    }
}

回答类:

代码语言:javascript
复制
package com.wazn.learn.entity.teachclass;

import java.util.Date;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;

import com.fasterxml.jackson.annotation.JsonBackReference;
import com.wazn.learn.entity.sys.User;
@Entity
@Table(name="teach_answer")
public class Answer {
    
    private Integer id;
    private String content;
    private Date hftime;
    private User userid;//教师id
    private Questions question;
    
    
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    
    @Column(nullable=false)
    public String getContent() {
        return content;
    }
    public void setContent(String content) {
        this.content = content;
    }

    public Date getHftime() {
        return hftime;
    }
    public void setHftime(Date hftime) {
        this.hftime = hftime;
    }
    @ManyToOne
    @JoinColumn(name="u_id",nullable=false,insertable=true)
    public User getUserid() {
        return userid;
    }
    public void setUserid(User userid) {
        this.userid = userid;
    }
    
    @ManyToOne
    @JoinColumn(name="q_id",nullable=false,insertable=true)
    @JsonBackReference
    public Questions getQuestion() {
        return question;
    }
    @JsonBackReference
    public void setQuestion(Questions question) {
        this.question = question;
    }
    @Override
    public String toString() {
        return "Answer [id=" + id + ", content=" + content + ", hftime=" + hftime + ", userid=" + userid + ", question="
                + question + "]";
    }

}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-12-19 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档