mysql语句:根据某一个字段重复,只取list中第一条数据

select s.*  
from ( 
    select b.*, row_number() over (partition by b.[重复字段] order by b.[排序字段]) as group_idx  
    from table_name b
) s
where s.group_idx = 1

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可以使用Spring Data JPA的@Query注解和自定义查询语句来实现。 假设有一个实体类User,其有两个属性id和name,需要获所有用户的id并存储到一个数组,可以按照以下步骤操作: 1. 在UserRepository接口定义一个自定义的查询方法,使用@Query注解指定查询语句,例如: ```java public interface UserRepository extends JpaRepository<User, Long> { @Query("SELECT u.id FROM User u") List<Long> findAllIds(); } ``` 2. 在需要使用的地方注入UserRepository,并调用findAllIds方法获所有id,例如: ```java @Service public class UserService { @Autowired private UserRepository userRepository; public void getAllIds() { List<Long> ids = userRepository.findAllIds(); // 对ids进行处理 } } ``` 在以上代码,findAllIds方法返回的是一个包含所有id的List集合,可以根据实际需要进行处理。 如果需要获多个字段的多个数据,只需在查询语句选择需要的字段即可。例如,如果需要获所有用户的id和name并存储到一个Map,可以按照以下方式修改查询语句: ```java @Query("SELECT u.id, u.name FROM User u") List<Object[]> findAllIdsAndNames(); ``` 返回的List每个元素都是一个包含id和name的Object数组,可以使用Map来存储: ```java public void getAllIdsAndNames() { List<Object[]> results = userRepository.findAllIdsAndNames(); Map<Long, String> idNameMap = new HashMap<>(); for (Object[] result : results) { Long id = (Long) result[0]; String name = (String) result[1]; idNameMap.put(id, name); } // 对idNameMap进行处理 } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值