一对多查询时报错:
StackOverflowError :StackOverflowError在程序栈空间耗尽时抛出,通常是深度递归导致。
就是说:方法在调用时,无限成立且循环执行,消耗内存,报错栈内存溢出。
在一对多关联表两个对象的toString方法重写之后,应用程序递归太深了,所以发生了堆栈溢出。
解决:
1....去除一个表中的toString()方法。(这是最简单的方法,但是这样打印出来的结果只是订单的内存地址,不易查看)
A表需要B表的对象,B表同时需要A表的对象,才能获得成立,这是条件,所以会无限成立调用,直至内存耗尽。
去除toSting这样可以避免互相调用,改变永恒成立。
2....去除一个表中的toString()方法中的另一张表的属性对象(既:属性变量cities)。
改前::::
@Override
public String toString() {
return "Flighties{" +
"id=" + id +
", flightNo='" + flightNo + '\'' +
", arriveDate=" + arriveDate +
", cities=" + cities +
'}';
}
改为::::
@Override
public String toString() {
return "Flighties{" +
"id=" + id +
", flightNo='" + flightNo + '\'' +
", arriveDate=" + arriveDate +
'}';
}
3....用其中的一个对象去设置另一个对象值为空null。
1 @Test
2 @Transactional //事务 必须加
3 public void test01(){
4 //根据id 查询
5 Cities one = citiesDao.findOne(1l);
6
7 Set<Flighties> flighties = one.getFlighties();
8 for(Flighties flight:flighties){
9 flight.setCities(null);//提前终止,不会无限递归下去
10 System.out.println(flight);
11 }
12 }