一开始用jpa加上jackson自动转换对象为json数据 前台用vue觉得很方便
然后做分页的时候,发现查询一个对象,会这个对象关联的表都查询一遍,这样就会太慢,然后关联表也会出问题。
网上看了一些方法 把OneToMany对象设置懒加载 把ManyToOn对象设置EAGER 然后我返回对象的时候发现还是查询了一对多的表
比如客户表下面有OneToMany对应的联系人表 和 OneToMany对应的合同表 做分页的时候不用查关联表的内容
用@JsonIgnore忽略的话 set集合就不能用了 这个方法不可取
设置懒加载测试可以起作用 但是jackson转换对象为json时会自动访问关联表 相当于懒加载没有起作用
还有就是在表中关于ManyToOne的类属性 比如客户表下面的区域表为ManyToOne这个属性如果设置为懒加载会直接报错 不能序列化
公司有用Gson手动转json字符串的方法 ,相当于把查询的对象又包装了一个类 ,这样的方法有好几种,但是很麻烦,每个属性都需要再重新写一次,如果属性未知的话,很难实现。
我的目的就是想在查询一张表的时候,查询这个表下面关联的其他表的第一层数据 不去查询关联表下面再关联的数据。
最后还是把所有ManyToOne 和 OneToMany 都是设置懒加载属性 这样ManyToOne会报错需要给One的实体类上加
@JsonIgnoreProperties(value={"hibernateLazyInitializer","handler","fieldHandler"}) 这个类没有关联Many方的数据的时候
就不会查询json字符串为null 有数据的时候会用新的select语句查询