凭什么Sql语句查询出来的数据可以用实体类接收

我们先来看代码:

Dao层根据id查询方法

@Query("select * from test where id = ?")
PermissionsLogDTO findByPermissionsId(Long id);

用来接收的实体类:

public class PermissionsLogDTO  {
   


    /**
     * 日志ID
     */

    private Integer logId;
    /**
     * 流程表ID
     */

    private Long permissionsId;

    /**
     * 最后改变时间
     */

    private Date lastChangetime;
    /**
     * 改变人
     */
    private String updateUserid;
    /**
     * 状态
     */
    private Integer status;
    /**
     * 租户id
     */
    private Integer tenantId;
}

Controller层代码:

  @Autowired
    PermissionsLogRepository permissionsLogRepository;
    @GetMapping("/test")
    public PermissionsLogDTO rtest(String id) {
        long lid = Long.parseLong(id);
        PermissionsLogDTO byPermissionsId = permissionsLogRepository.findByPermissionsId(lid);
        log.info(byPermissionsId.toString());
        return byPermissionsId;
    }

postman访问:
在这里插入图片描述
直接报错:

java.lang.reflect.InvocationTargetException

这个时候我们在接收类里面加上全参构造:

    public PermissionsLogDTO(Integer logId, Long permissionsId, Date lastChangetime, String updateUserid, Integer status, Integer tenantId) {
        this.logId = logId;
        this.permissionsId = permissionsId;
        this.lastChangetime = lastChangetime;
        this.updateUserid = updateUserid;
        this.status = status;
        this.tenantId = tenantId;
    }

再次访问:

PermissionsLogDTO{logId=102, permissionsId=1413043148779294720, lastChangetime=2021-07-08 15:51:54.0, updateUserid='04987', status=1, tenantId=2288}

成功接收到了参数。
综上所述:Sql语句查询出来的数据可以用实体类接收的条件就是通过全参的构造函数将查出来的值一一赋值到实体类中。
为了进一步论证这个结果,我们将构造器中的lastchangetime删除掉:

 public PermissionsLogDTO(Integer logId, Long permissionsId, String updateUserid, Integer status, Integer tenantId) {
        this.logId = logId;
        this.permissionsId = permissionsId;
        this.updateUserid = updateUserid;
        this.status = status;
        this.tenantId = tenantId;
    }

输出来的结果显示:

PermissionsLogDTO{logId=102, permissionsId=1413043148779294720, lastChangetime=null, updateUserid='04987', status=1, tenantId=2288}

很明显lastChangetime的值变为空了。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

掉头发的王富贵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值