Fastjson序列化致使BeetlSQL无限循环查询的解决方案

前言

BeetlSQL最近的更新新增了@OrmQuery注解,做用是能够让内置生成的SQL自动去延迟级联加载对象,此功能的增长让BeetlSQL在ORM功能方面彻底有了抗衡Hibernate的资本。这么新鲜刺激的功能,不尝鲜一下简直对不起正使用BeetlSQL的本身,更是对不起BeetlSQL的做者@闲·大赋呢!git

问题与场景

假定有城市City和省份Province两个Pojo,分别都注解上了@OrmQuery,本意是想当查询城市City时能延迟级联查询对应的省份Province,或查询省份Province时能够延迟级联查询该省份下面的所有City列表,理想很丰满,现实却很骨感。咱们直接使用Beetl或者JSP等模板引擎直接在页面上输出以及级联加载时没有任何问题。sql

凡事都有个可是~~~当咱们使用Fastjson序列化某一个查询结果时可怕的事情发生了,互相@OrmQuery致使Fastjson序列化时会一直查询下去,相似于死循环。数据库

举个栗子,具体表现为:当查询深圳市,由于有@OrmQuery级联关系,Fastjson自动序列化到tails(tails为Pojo继承了TailBean后的一个属性,用于BeetlSQL内部级联加载时存放代理对象等使用)的province时BeetlSQL又会去数据库查询广东省,而后Fastjson继续序列化广东省,序列化到广东省的tails下面的city时BeetlSQL又会去数据库获取整个广东省下面的city列表,而后Fastjson又会一一序列化每一个city,每一个city里面又有tails,如此反复...简直就是死循环,仍是拉上数据库一块儿死的节奏。。json

解决方案

其实解决方法很简单,当两个Pojo若是双方互相都设置了@OrmQuery请至少给一方设置一个Fastjson的注解@JSONType(ignores="tails"),让Fastjson中断序列化BeetlSQL级联查询的关键小尾巴tails.net

相关文章
相关标签/搜索