JPA写原生查询的时候似乎需要返回全部字段

@Transactional
    @Query(value="select *,(ABS(angle_1-?1)+ABS(angle_2-?2)+ABS(angle_3-?3)) as matching from side_statistic_result HAVING matching is not null ORDER by matching asc limit 1", nativeQuery=true)
    SideStatisticResult findMatchingResult(double angle1, double angle2, double angle3);

上面可以,但是*和matching换一个位置后会报找不到字段的错误

原文链接:http://blog.maptoface.com/post/158 

JPA 中,可以使用以下方法来指定返回字段: 1. 使用 @Query 注解:可以在自定义的查询方法上使用 @Query 注解,通过编 JPQL 或者原生 SQL 查询语句来指定返回字段。在查询语句中,可以使用 SELECT 关键字来选择需要返回字段,例如: ```java @Repository public interface UserRepository extends JpaRepository<User, Long> { @Query("SELECT u.name, u.age FROM User u") List<Object[]> findUserNameAndAge(); } ``` 上述代码中,使用 @Query 注解指定了一个自定义查询方法,查询返回的是一个 Object 数组,包含了 name 和 age 两个字段。 2. 使用 Projections:JPA 还提供了 Projections 的功能,可以通过接口的方式来定义需要返回字段。首先定义一个接口,接口中声明需要返回字段名和对应的 getter 方法: ```java public interface UserNameAndAge { String getName(); Integer getAge(); } ``` 然后在 Repository 中使用 Projections 的方式来指定返回字段: ```java @Repository public interface UserRepository extends JpaRepository<User, Long> { List<UserNameAndAge> findByName(String name); } ``` 上述代码中,定义了一个 UserNameAndAge 接口,包含了 getName() 和 getAge() 方法。在 UserRepository 中使用该接口作为返回类型,JPA 会自动根据接口方法名来生成查询语句,并返回符合接口定义的字段。 这些是两种常用的方式来指定返回字段,你可以根据具体的需求选择适合的方法。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

全职计算机毕业设计

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

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

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

打赏作者

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

抵扣说明:

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

余额充值