您好,登录后才能下订单哦!
这篇文章主要介绍“Spring JPA find单表查询方法怎么使用”,在日常操作中,相信很多人在Spring JPA find单表查询方法怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Spring JPA find单表查询方法怎么使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
通过id进行单条查询,先看看 findById(ID id) 的源码
@Override public Optional<T> findById(ID id) { Assert.notNull(id, ID_MUST_NOT_BE_NULL); Class<T> domainType = getDomainClass(); if (metadata == null) { return Optional.ofNullable(em.find(domainType, id)); } LockModeType type = metadata.getLockModeType(); Map<String, Object> hints = new HashMap<>(); getQueryHints().withFetchGraphs(em).forEach(hints::put); return Optional.ofNullable(type == null ? em.find(domainType, id, hints) : em.find(domainType, id, type, hints)); }
从源码可以看出,最终调用的是EntityManager的find方法,EntityManager是jpa用来做持久化的,有空可以跟大家探讨一下!
下面是控制台的输出:
Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_, user0_.name as name3_0_0_ from user user0_ where user0_.id=?
查找所有的数据,源码如下:
@Override public List<T> findAll() { return getQuery(null, Sort.unsorted()).getResultList(); }
从源码可以看出,最终调用了org.hibernate.Query
的getResultList方法。
控制台输出如下:
Hibernate: select user0_.id as id1_0_, user0_.age as age2_0_, user0_.name as name3_0_ from user user0_
通过ids进行多条查询,源码如下:
@Override public List<T> findAllById(Iterable<ID> ids) { Assert.notNull(ids, "Ids must not be null!"); if (!ids.iterator().hasNext()) { return Collections.emptyList(); } if (entityInformation.hasCompositeId()) { List<T> results = new ArrayList<>(); for (ID id : ids) { findById(id).ifPresent(results::add); } return results; } Collection<ID> idCollection = Streamable.of(ids).toList(); ByIdsSpecification<T> specification = new ByIdsSpecification<>(entityInformation); TypedQuery<T> query = getQuery(specification, Sort.unsorted()); return query.setParameter(specification.parameter, idCollection).getResultList(); }
从源码可以看出,跟findAll方法一样,最终调用的是org.hibernate.Query
的getResultList方法,只不过加了id的集合。
控制台打印如下:
Hibernate: select user0_.id as id1_0_, user0_.age as age2_0_, user0_.name as name3_0_ from user user0_ where user0_.id in (? , ?)
control层
@GetMapping("findAllById") public List<User> findAllById(Integer[] ids) { return userService.findAllById(Arrays.asList(ids)); }
根据sort对象对所有数据进行相应的排序
@Override public List<T> findAll(Sort sort) { return getQuery(null, sort).getResultList(); }
这个源码也是没啥可看的!需要注意的就是这个sort对象。
这个sort对象是需要我们自己去创建,然后根据自己的诉求传入相应的参数。这里我们就是使用sort.by来实现吧(也可以通过其他方法)
/** * Creates a new {@link Sort} for the given {@link Order}s. * * @param direction must not be {@literal null}. * @param properties must not be {@literal null}. * @return */ public static Sort by(Direction direction, String... properties) { Assert.notNull(direction, "Direction must not be null"); Assert.notNull(properties, "Properties must not be null"); Assert.isTrue(properties.length > 0, "At least one property must be given"); return Sort.by(Arrays.stream(properties)// .map(it -> new Order(direction, it))// .collect(Collectors.toList())); }
可以看到我们需要传入两个参数,分别是 direction 和 properties:
direction 是排序方向(升序或降序)
properties 是排序的对象,是个数组(可以是单个也可以是多个)
@GetMapping("findAllSort") public List<User> findAllSort(String ascOrDesc, String[] para) { Sort sort; if(ascOrDesc.toLowerCase().equals("desc")){ sort = Sort.by( Sort.Direction.DESC, para); }else { sort = Sort.by( Sort.Direction.ASC, para); } return userService.findAllSort(sort); }
请求 findAllSort?ascOrDesc=desc¶=age,name
,对 age 和 name 进行降序排序,结果如下:
[{ "id": 21, "name": "bb", "age": 12 }, { "id": 22, "name": "cc", "age": 11 }, { "id": 20, "name": "aa", "age": 11 }]
控制台输出如下:
Hibernate: select user0_.id as id1_0_, user0_.age as age2_0_, user0_.name as name3_0_ from user user0_ order by user0_.age desc, user0_.name desc
上面的只能进行单调的排序,就是说多个对象只能一同升序或者降序;而在实际需求中,有时候还需要对多个对象,进行不同的排序,有的升序,有的降序。想要完成这样的查询,我们还是需要依靠sort对象去实现。sort.by 的入参中还有可以传 order 数组和列表,我们就利用数组和列表对数据进行多参数的多样排序,话不多说,直接上码。
/** * Creates a new {@link Sort} for the given {@link Order}s. * * @param orders must not be {@literal null}. * @return */ public static Sort by(List<Order> orders) { Assert.notNull(orders, "Orders must not be null"); return orders.isEmpty() ? Sort.unsorted() : new Sort(orders); } /** * Creates a new {@link Sort} for the given {@link Order}s. * * @param orders must not be {@literal null}. * @return */ public static Sort by(Order... orders) { Assert.notNull(orders, "Orders must not be null"); return new Sort(Arrays.asList(orders)); }
@GetMapping("findAllMoreSort") public List<User> findAllMoreSort(String[] sorts,String[] paras) { int length = sorts.length; //Sort.Order[] orders = new Sort.Order[length]; List<Sort.Order> listOrder = new ArrayList<>(); for(int i=0; i<length; i++){ // orders[i] = new Sort.Order(sorts[i].toLowerCase().equals("asc") ? // Sort.Direction.ASC : Sort.Direction.DESC, paras[i]); listOrder.add(new Sort.Order(sorts[i].toLowerCase().equals("asc") ? Sort.Direction.ASC : Sort.Direction.DESC, paras[i])); } //Sort sort = Sort.by(orders); Sort sort = Sort.by(listOrder); return userService.findAllSort(sort); }
请求findAllMoreSort?sorts=asc,desc¶s=age,name
,对age升序,对name降序,结果如下:
[{ "id": 22, "name": "cc", "age": 11 }, { "id": 20, "name": "aa", "age": 11 }, { "id": 21, "name": "bb", "age": 12 }]
控制台输出如下:
Hibernate: select user0_.id as id1_0_, user0_.age as age2_0_, user0_.name as name3_0_ from user user0_ order by user0_.age asc, user0_.name desc
到此,关于“Spring JPA find单表查询方法怎么使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。