栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

JPA CriteriaBuilder

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JPA CriteriaBuilder

假设实体客户具有如下

OneToMany
属性:

@oneToMany(mappedBy = "customerId")private Collection<Order> orders;

您可以使用以下查询:

EntityManager em;  // to be built or injectedCriteriaBuilder cb = em.getCriteriaBuilder();CriteriaQuery<Tuple> cq = cb.createTupleQuery();Root<Customer> customer = cq.from(Customer.class);CollectionJoin<Customer, Order> orders = customer.join(Customer_.orders, JoinType.LEFT);cq.select(cb.tuple(customer, cb.count(orders)));cq.where(... add some predicates here ...);cq.groupBy(customer.get(Customer_.id));cq.orderBy(cb.desc(cb.count(orders)));List<Tuple> result = em.createQuery(cq).getResultList();for (Tuple t : result) {    Customer c = (Customer) t.get(0);    Long cnt = (Long) t.get(1);    System.out.println("Customer " + c.getName() + " has " + cnt + " orders");}

上面的方法使用metamodel。如果你不喜欢它,你可以替换

Customer_.orders
使用
"orders"
,并
Customer_.id
"id"

如果

OneToMany
财产是另一种类型的,更换
CollectionJoin
用正确类型的集合(
ListJoin
SetJoin
MapJoin
)。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/377022.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号