jpa执行原生sql,返回自定义对象(好文章!!)

141 篇文章 5 订阅
25 篇文章 1 订阅

jpa执行原生sql,返回自定义对象


前言:我之前是用mybatis的,到了一个新公司,用的是hibernate了,感觉非常不适用,想写原生sql,百度了一天,有说用接口的,有说用工具类的,都不合我意,偶然看到一位大神的博客,不记得地址了,感谢,侵删。
废话少说,直接上代码:

我要实现这样的sql,
select a.name,a.address,b.password,b.phone from tableA a inner join tableB b on a.bid = b.id 
where a.id=:id and b.key=:key;


#第一步,先引入阿里的fastjson

 <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.56</version>
        </dependency>


#第二步

//repository层用List<Map<String,String>>接收返回的数据
List<Map<String,Object>> findOther(@Param("id")String id,@Param("key")String key);
//service层
List<Map<String,Object>> irsData = recordLogRepository.findOther(id,key);
String irsStr = JSON.toJSONString(irsData);
List<ListPatientHistoryDto> irsList = JSON.parseArray(irsStr, ListPatientHistoryDto.class);

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JPA 中,你可以使用以下几种方式来返回自定义对象: 1. 使用构造函数表达式:你可以在查询中使用构造函数表达式来创建自定义对象。假设你有一个名为 `CustomObject` 的类,它有一个带有参数的构造函数,你可以在查询中使用这个构造函数来返回自定义对象。例如: ```java String jpql = "SELECT NEW com.example.CustomObject(c.name, c.age) FROM Customer c"; TypedQuery<CustomObject> query = entityManager.createQuery(jpql, CustomObject.class); List<CustomObject> resultList = query.getResultList(); ``` 2. 使用 `@SqlResultSetMapping`:你可以在实体类中使用 `@SqlResultSetMapping` 注解来定义结果映射。首先,在实体类中定义一个构造函数,然后在 `@SqlResultSetMapping` 注解中指定该构造函数的参数映射。例如: ```java @SqlResultSetMapping( name = "CustomObjectMapping", classes = @ConstructorResult( targetClass = CustomObject.class, columns = { @ColumnResult(name = "name", type = String.class), @ColumnResult(name = "age", type = Integer.class) } ) ) @Entity public class Customer { // ... } ``` 然后,在查询时使用 `@SqlResultSetMapping` 注解的名称来指定结果映射。例如: ```java String jpql = "SELECT c.name, c.age FROM Customer c"; TypedQuery<CustomObject> query = entityManager.createNativeQuery(jpql, "CustomObjectMapping"); List<CustomObject> resultList = query.getResultList(); ``` 3. 使用投影(Projection):你可以使用投影的方式来选择实体类的部分属性,并将它们映射到自定义对象中。例如: ```java String jpql = "SELECT c.name, c.age FROM Customer c"; TypedQuery<Object[]> query = entityManager.createQuery(jpql, Object[].class); List<Object[]> resultList = query.getResultList(); List<CustomObject> customObjects = resultList.stream() .map(objArr -> new CustomObject((String) objArr[0], (Integer) objArr[1])) .collect(Collectors.toList()); ``` 这些是几种常见的在 JPA返回自定义对象的方式。你可以根据具体的业务需求选择最适合你的方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值