博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Fastjson序列化导致BeetlSQL无限循环查询的解决方案
阅读量:6212 次
发布时间:2019-06-21

本文共 817 字,大约阅读时间需要 2 分钟。

hot3.png

###前言

最近的更新新增了@OrmQuery注解,作用是可以让内置生成的SQL自动去延迟级联加载对象,此功能的增加让在ORM功能方面完全有了抗衡Hibernate的资本。这么新鲜刺激的功能,不尝鲜一下简直对不起正使用的自己,更是对不起的作者呢!

###问题与场景

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

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

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

###解决方案

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

转载于:https://my.oschina.net/yz1234/blog/792576

你可能感兴趣的文章
算法系列15天速成——第十四天 图【上】
查看>>
phonegap入门–1 Android 开发环境搭建
查看>>
Ice_cream's world I
查看>>
org.apache.subversion.javahl.ClientException: svn: E155021: This client is too old to work with the
查看>>
Memcached 服务器端命令
查看>>
ExtJs之Ext.form.field.TimePicker DatePicker组合框
查看>>
移动前端开发基础与优化
查看>>
form表单中的带有name的标签直接转JSON
查看>>
Struts2之Action
查看>>
Python3.4 12306 2015年3月验证码识别
查看>>
使用Gitblit 在windows 上部署你的Git Server
查看>>
object pool
查看>>
SQL FOR XML
查看>>
9年经验,总结SEO职业瓶颈
查看>>
js 上一步 下一步 操作
查看>>
Linux下的Cacti网络管理系统---安装(二)
查看>>
[置顶] 步步辨析JS中的对象成员
查看>>
上门送装家具建材已成趋势 还在“跑断腿”就OUT了!
查看>>
双11黑科技,阿里百万级服务器自动化运维系统StarAgent揭秘
查看>>
聊聊sentinel的SimpleHttpCommandCenter
查看>>