SpringDateJpa 查询返回自定义对象,非po对象。

1.使用原生sql查询。自定义接受类为对象,(貌似不支持对象属性)。

@Repository
public interface UserRepository extends JpaRepository<User,String> {

    @Query(value = "select * from User",nativeQuery = true)
    List<IUserDTO> selectIUserDTO();

}
package com.example.test1.dto;

public interface IUserDTO {
    String getId();
    String getName();
    String getAge();
}

参考

https://my.oschina.net/xiwanglr/blog/3067932

https://blog.csdn.net/kuangniaokuang/article/details/105249490

https://www.baeldung.com/spring-data-jpa-projections

2.hql。

    @Query("select new com.example.test1.dto.UserDTO(u.id,u.age,u.name) from User u where u.id=1")
    UserDTO selectUserDTO();
package com.example.test1.dto;

public class UserDTO {
    private String id;
    private String age;
    private String name;

    @Override
    public String toString() {
        return "UserDTO{" +
                "id='" + id + '\'' +
                ", age='" + age + '\'' +
                ", name='" + name + '\'' +
                '}';
    }

    public UserDTO(String id, String age, String name) {
        this.id = id;
        this.age = age;
        this.name = name;
    }

    public UserDTO() {
    }

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getAge() {
        return age;
    }

    public void setAge(String age) {
        this.age = age;
    }

    public String getName() {
        return name;
    }

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

 

Java中的PO对象是指持久化对象(Persistent Object),用于在程序和数据库之间进行数据传输和映射。下面是编写Java PO对象的一般步骤: 1. 创建一个Java类,并确定类名,通常以数据表名或业务实体名命名。例如,如果有一张名为"student"的数据表,可以创建一个名为"Student"的Java类作为PO对象。 2. 在PO类中声明私有变量,变量的类型和名称应与数据表的字段对应。例如,如果数据表"student"中有字段"id"和"name",则PO类中应该有私有变量"private int id;"和"private String name;"。 3. 使用Java Bean的规范,为每个私有变量添加相应的公有Getter和Setter方法,用于读取和设置私有变量的值。 4. 实现toString()方法,用于将PO对象转换为字符串,便于日志输出或调试。 5. 可选地,可以为PO类添加其他方法,如equals()和hashCode(),以提供对象的比较和哈希值计算功能。 示例代码如下: ```java public class Student { private int id; private String name; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "Student [id=" + id + ", name=" + name + "]"; } } ``` 以上是编写Java PO对象的一般步骤和示例代码。PO对象可以用于将程序中的数据映射到数据库中的表结构,并方便进行数据的存取和传输。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值