JPA MySql 同时对两个字段进行in的查询

JPA

List<UserBoatInfoEntity> findByAccountIdInAndBoatIdIn(List<String> accountIdList, List<String> boatIdList);

MySql

SELECT * FROM "user_boat_info"
where (account_id,boat_id)
in 
(
	('009mbNpLqDmmfVG6bFb', 'HVXxZcyz443bgzol81w'),
	('00fAlgLs0zgmx4I5fi3', '4ZK8bTxVfeRiruwPWQl'),
	('00fAlgLs0zgmx4I5fi3', '1DQ9NVOlyiMUyGzhlOZ')
)

可以使用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进行处理 } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

宁漂打工仔

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

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

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

打赏作者

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

抵扣说明:

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

余额充值