CriteriaBuilder 联合查询

public List<String> findProdFactoryDesc(String prodtype, String prodName) {

CriteriaBuilder cb = entityManager.getCriteriaBuilder();

CriteriaQuery<String> cq = cb.createQuery(String.class);

Root<Product> prt = cq.from(Product.class);

Root<Factory> fct =cq.from(Factory.class);

Predicate pType=cb.equal(prt.get("type"), prodtype);

Predicate pName=cb.equal(prt.get("name"),prodName);

Predicate prtAnd=cb.and(pType,pName);

Predicate facType=cb.equal(fct.get("prodType"), prodtype);

Predicate facName=cb.equal(fct.get("prodName"),prodName);

Predicate facAnd=cb.and(facType,facName);

Predicate prtFacAnd=cb.and(prtAnd,facAnd);

cq.where(prtFacAnd);

cq.multiselect(fct.get("ftyDesc")).distinct(true);

List<String> list = entityManager.createQuery(cq).getResultList();

return list;

}

相关推荐
fengyehongWorld21 分钟前
Linux wget命令
linux
J小黄31 分钟前
解决IRQL_NOT_LESS_OR_EQUAL蓝屏,IMAGE_NAME: ntkrnlmp.exe
windows
fpcc1 小时前
跟我学C++中级篇——Linux系统信号分析
linux
楼田莉子1 小时前
基于Linux的个人制作的文件库+标准输出和标准错误
linux·c语言·c++·学习·vim
♛识尔如昼♛1 小时前
Linux I2C 驱动
linux·驱动开发·i2c 协议
面向星辰1 小时前
windows10计算机管理和系统高级选项窗口
windows
_OP_CHEN2 小时前
【Git原理与使用】(一)告别文件混乱!Git 初识:从版本灾难到高效管理的终极方案
linux·运维·git·github·运维开发·版本控制·企业级组件
装不满的克莱因瓶2 小时前
【Java架构 搭建环境篇三】Linux安装Git详细教程
java·linux·运维·服务器·git·架构·centos
博语小屋2 小时前
线程同步与条件变量
linux·jvm·数据结构·c++
至善迎风2 小时前
Linux 服务器安全防护工具完全指南
linux·服务器·安全·防火墙