SSH多表查询对象转json

在项目中将Hibernate查询的对象转换为JSON时遇到循环引用和非字符串属性导致的错误。通过理解对象转JSON的顺序,排除级联关系可能导致循环的字段,并处理非字符串属性,最终成功转换。设置lazy为false避免错误,通过JsonConfig过滤字段,完成JSON转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近做的项目是需要把对象转成json传到前台去,实现异步刷新的效果。不巧的是在转化过程中碰到了一些问题,郁闷了好久,在参考别人的意见之前,终于搞定了。哈哈!!!将我的想法记录下来,以做参考之用,贴上部分源码作为理解之用。

     由于Hibernate级联关联关系,使得我们对查询出来的对象进行Json转换的时候失败。要解决这个问题,首先我们需要知道的是在将对象转为Json的时候,是一个怎样的过程(即属性转Json的顺序)。当我们将对象查询出来后,使用fromObject时,解析的过程是这样的,它会以Javabean申明的属性顺序依次转为json。在转换过程中如果碰到了级联关系,那么它就会跳入进去,接着转关联JavaBean属性,因此这个过程就有可能会造成这样的错误(net.sf.json.JSONException: There is a cycle in the hierarchy!),所以说对对象进行转换成json的时候,就需要排除这样的字段。简单的说就是从一个对象开始顺序转,不要让这个过程出现回调的情况。

     接着在我们排除了那些可能会引起 There is a cycle in the hierarchy这样错误字段之后,就可以继续剩余的属性转换了。然后不行的是又出现了其他问题(net.sf.json.JSONException: java.lang.reflect.InvocationTargetException),根据字面上的意思就是说存在一个不能映射的属性,在排查和寻找资料后发现,原来要将对象转为json的条件是属性必须是字符串或者对象,否则都会报刚才的错误,所以这里需要我们对其处理一下,要么就舍弃那些非字符串属性,要么就先处理成字符串然后在转。

   排除了以上的字段后,终于可以转成json了。输出结果如下:

[{"channel":"邮件","operation":{"content":"更新用户目录下lib中的so文件\r\n"..........


我这里使用JsonArray的方法,我想其他的也是类似,就不多说了。如有不对之处,欢迎各位吐槽,我们共同进步!!! 微笑

public class User implements Serializable {

	/**
	 * 序列化,实现对等传输
	 */
	private static final long serialVersionUID = 1L;

	/**
	 * 用户ID
	 */
	private Integer userId; 
	
	/**
	 * NT账号
	 */
	private String nt;
	
	/**
	 * 用户真实姓名
	 */
	private String username;
	
	/**
	 * 密码
	 */
	private String password;
	
	
	/**
	 * 补丁操作表
	 */
	private Set<Operation> operations;
}


 user. hbm.xml: 

  <set name="operations" inverse = "true" <span style="color:#ff0000;">lazy = "false"</span>>
  	<key column = "userId" />
  	<one-to-many class = "Operation"/> 
  </set>


 切记这里的lazy要设置为false,否则程序会报错。

现在单元测试一下,


Patch pt = patchbiz.queryByPatchId(22);
		
<span style="color:#ff0000;">config.setExcludes(new String[]{"operations","patchSystem","start","end"})</span>;//这里的意思是说把那些会引起级联查询的字段排除,以及不是字符串类型。
		
JSONArray mgs = JSONArray.fromObject(patches, config);
System.out.println(mgs);


或者

 config.setJsonPropertyFilter(new PropertyFilter() {
        public boolean apply(Object source, String name, Object value) {
        	if (source instanceof User && name.equals("operations")) {
                    return true;
               <span style="white-space:pre">	</span>else {
                    return false;
                }
        }
});<pre name="code" class="html">		
JSONArray mgs = JSONArray.fromObject(patches, config);
System.out.println(mgs);

 


详情可以参考以下博文内容:

配置JsonConfig过滤有可能引起循环的字段

JsonConfig

JSON--List集合转换成JSON对象




评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值