JPA查询返回自定义对象

JPA查询返回自定义对象

说明:
select后面是new + 实例化对象的全路径,构造函数就是构建自己想要写入该实体对象对应的属性的值,且语法与hql写法相同,注意不要设置@Query注解nativeQuery属性的值,使用默认值即可;

import cn.alqingge.dto.FilingHistoryDTO;
import cn.alqingge.entity.FilingFinancialAccountingSystemEntity;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;

import java.util.List;

/**
 * @author alqingge@gogpay.cn
 * @date 2020/6/15 11:29
 */
public interface FilingFinancialAccountingSystemRepository extends JpaRepository<FilingFinancialAccountingSystemEntity, String> {

    /**
     * 通过用户id查询用户提交的历史记录
     *
     * @param userId
     * @return
     */
    @Query(value = "SELECT new cn.gogpay.dcb.province.taxation.dto.FilingHistoryDTO(s.name, s.startDate, s.endDate) " +
            "FROM FilingFinancialAccountingSystemEntity AS s WHERE s.userId = ?1")
    List<FilingHistoryDTO> findAllByUserId(String userId);
}
package cn.alqingge.dto;

import com.alibaba.fastjson.JSON;

/**
 * @author aliqingge@gogpay.cn
 * @date 2020/6/15 11:34
 */
public class FilingHistoryDTO {

    /**
     *名称
     */
    private String name;

    /**
     * 有效期起
     */
    private String startTime;

    /**
     * 有效期止
     */
    private String endTime;

    public FilingHistoryDTO() {
    }

    public FilingHistoryDTO(String name, String startTime, String endTime) {
        this.name = name;
        this.startTime = startTime;
        this.endTime = endTime;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getStartTime() {
        return startTime;
    }

    public void setStartTime(String startTime) {
        this.startTime = startTime;
    }

    public String getEndTime() {
        return endTime;
    }

    public void setEndTime(String endTime) {
        this.endTime = endTime;
    }

    @Override
    public String toString() {
        return JSON.toJSONString(this);
    }
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值