亲宝软件园·资讯

展开

springboot嵌套子类使用

鲸鱼姐 人气:0

springboot嵌套子类使用

在实际项目里,我们会使用到一个User用户含有子类Address、这种嵌套子类在开发中会遇到很多问题,现在主要针对前台和后台的开发问题进行整理。

实际Bean类

User类里含有Address类

public class User {
    private int userId;
    private String userName;
    private Address userAddress;
}
public class Address 
{
    private int addressId;
    private String city;
//忽略get、set方法
}

UserMapper.java  对于一对一

使用@Result注解,调用查询子类数据。

public interface UserMapper
{
    //one to one 
    @Select("select * from user where userId = #{userId}")
    @Results({
        @Result(id=true,column="userId",property="userId"),
        @Result(column="userName",property="userName"),
@Result(column="userId",property="userAddress",one=@One(select="com.whale.mapper.AddressMapper.getAddressByUserId",fetchType= FetchType.EAGER))
})
public interface AddressMapper 
{
    @Select("select * from address where userId=#{userId}")
    public Address getAddressByUserId(int userId);
}

前台使用bootstrap-table进行解析显示

在formmater里进行子类显示

columns: [{
            checkbox : true
        }, {
            field: 'userId',
            title: '用户ID'
        }, {
            field: 'userName',
            title: '用户姓名'
        }, {
            field: 'userAddress',
            title: '地址',
            formatter : function(value,row, index){   //主要配置在这里
                return value.city;
            }
        }
        ]

后台Controller转换成Json会出现 $ref

解决办法如下:

注意:

String jsonSting=JSON.toJSONString(result, SerializerFeature.DisableCircularReferenceDetect); 

结果中出现$ref,先把JSONObject转换成String,然后再转换回JSONObject

  @ResponseBody
    @RequestMapping("allUser")
    public String findALL(){     
        PageHelper.startPage(pageNumber,pageSize);
        List<User> userList= userService.findAll();
        PageInfo<User> page=new PageInfo<>(userList);
        //取出查询结果
        List<User> rows = page.getList();
        JSONObject result = new JSONObject();
 
        int total = (int) page.getTotal();
        result.put("total",total);
        result.put("rows",rows);
        String jsonSting=JSON.toJSONString(result, SerializerFeature.DisableCircularReferenceDetect);  //结果中出现$ref,先把JSONObject转换成String,然后再转换回JSONObject
        JSONObject json= JSON.parseObject(jsonSting);
        System.out.println(json.toJSONString());
}

注解在嵌套方法不生效问题

例如在service中方法如下

    @PermissionAop
    @Override
    public List<PoiPermission> getList() {
        List<PoiPermission> list = this.list();
        return list;
    }
    @Override
    public void test(){
        this.getList();
        System.out.println("");
    }

controller中调用test()方法,test方法中调用切面方法,切面不生效,无法进入切面。

使用如下方式可解决该问题(启动类上需要添加

@EnableAspectJAutoProxy(exposeProxy = true))
    @PermissionAop
    @Override
    public List<PoiPermission> getList() {
        List<PoiPermission> list = this.list();
        return list;
    }
 
    @Override
    public void test(){
        IPoiPermissionService service = (IPoiPermissionService) AopContext.currentProxy();
        service.getList();
        System.out.println("");
    }

其中IPoiPermissionService为该service类实现的接口。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

加载全部内容

相关教程
猜你喜欢
用户评论