zoukankan      html  css  js  c++  java
  • JPA默认方法查询遇到转JSON的处理

    JPA提供的findAll等查询方法在有关联的对象时

    比如:在查userInfo

    @Entity
    @Table(name = "user_info")
    public class UserInfo implements Serializable {
    @Id
    @GeneratedValue
    private Integer uid;
    @Column(unique =true)
    private String username;//帐号
    private String name;//名称(昵称或者真实姓名,不同系统不同定义)
    private String password; //密码;
    private String salt;//加密密码的盐
    private byte state;//用户状态,0:创建未认证(比如没有激活,没有输入验证码等等)--等待验证的用户 , 1:正常状态,2:用户被锁定.
    @ManyToMany(fetch = FetchType.EAGER)
    @JoinTable(name = "SysUserRole", joinColumns = { @JoinColumn(name = "uid") }, inverseJoinColumns ={@JoinColumn(name = "roleId") })
    private List<SysRole> roleList;// 一个用户具有多个角色

    // 省略 get set 方法

    关联的Role对象在userinfo对象转JSON数据返回时,会报无法序列化的异常,因为此时Role对象是代理类,无法实现序列化

    网友提供的方法有加json包的然后重写转换器的,有加jsonInogerjson的注解,感觉还是本人的方法直接

    首先新建一个model和entity字段一样的类

    然后直接转换后再转为json数据

    如下

    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    public class UserInfoResp {

    private Integer uid;
    private String username;//帐号
    private String name;//名称(昵称或者真实姓名,不同系统不同定义)
    private String password; //密码;
    private String salt;//加密密码的盐
    private byte state;//用户状态
    }
    @LoginToken
        @ApiOperation("查询用户列表")
        @RequiresPermissions("userInfo:view")
        @PostMapping("/userInfo/userList")
        public Result getUserList(@RequestBody UserInfoReq userInfoReq){
            log.info("查询用户列表");
            int page = NumberUtils.toInt(userInfoReq.getCurrentPage(), 0);
            int size = NumberUtils.toInt(userInfoReq.getPageSize(), 10);
            PageHelper.startPage(page,size);
            List<UserInfo> userList = userInfoService.getUserList();
            ArrayList<UserInfoResp> list = Lists.newArrayList();
            Iterator<UserInfo> it = userList.iterator();
            while (it.hasNext()){
                UserInfoResp resp = new UserInfoResp();
                BeanUtils.copyProperties(it.next(),resp);
                list.add(resp);
            }
            PageInfo pageInfo = new PageInfo<>(list);
            return Result.success(pageInfo);
        }

    这样迂回就可以得到JSON数据,而且model类还可以加自己需要的其他字段

    JPA的其他使用在记一下

    1、JPA提供的方法支持级联查询和级联删除

    2、自定义的删除和修改方法注意需要在service的方法上加事物

    @Transactional(rollbackFor = Exception.class ,propagation = Propagation.REQUIRED ,isolation = Isolation.READ_COMMITTED)
        public void updateRolePermission(SysRoleReq sysRoleReq){
            Integer rid = sysRoleReq.getId();
            Set<Integer> sets = sysRoleReq.getSets();
            sysRoleRepository.deleteRolePermission(rid);
            Iterator<Integer> iterator = sets.iterator();
            while (iterator.hasNext()){
                Integer next = iterator.next();
                sysRoleRepository.saveRolePermission(next,rid);
            }
        }

    自定义的方法注解使用如下

    @Repository
    public interface SysRoleRepository extends JpaRepository<SysRole,Integer> {


    @Modifying
    @Query(value = "insert into sys_role_permission(permission_id,role_id) values(?1,?2)",nativeQuery = true)
    int saveRolePermission(Integer pid, Integer rid);
    @Modifying
    @Query(value = "delete from sys_role_permission where role_id =?1)",nativeQuery = true)
    int deleteRolePermission(Integer rid);
    @Query(value = "select * from sys_role ",nativeQuery = true)
    List<SysRole> getRoleList();
    }
    nativeQuery=true表示为原生的sql

  • 相关阅读:
    HDOJ 2955
    SG函数
    关于背包问题的二进制优化
    一个还算能用的调试代码
    ural 1568 Train Car Sorting 题解
    【虚拟机】:"该虚拟机似乎正在使用中。 如果该虚拟机未在使用,请按“获取所有权(T)”按钮获取它的所有权。否则,请按“取消(C)”按钮以防损坏。"
    解决Zookeeper报错:conf is not executed because it is not in the whitelist的解决办法
    Kali Linux更新和配置
    Docker拉取镜像时错误解决办法
    运行连接Oracle数据库时,Idea报错: Error : java 不支持发行版本5
  • 原文地址:https://www.cnblogs.com/h-c-g/p/11018341.html
Copyright © 2011-2022 走看看