使用任意 AND 子句的动态 Spring Data JPA 存储库查询
简介
在 Spring Data JPA 中,使用以下方法构建动态查询由于默认查询机制的限制,可选字段可能具有挑战性。为了克服这些限制,可以采用规范等替代方法。
使用规范
规范提供了一种强大的方法来定义以编程方式查询实体的条件。通过在存储库接口中实现 JpaSpecificationExecutor 接口,您可以访问 findAll(Specification) 方法,该方法允许您直接执行规范。
规范由 toPredicate 方法组成,该方法采用 Root 和 CriteriaBuilder 作为参数并返回谓词。此谓词表示您的查询的搜索条件。
示例
考虑以下用于搜索客户的规范示例:
public class CustomerSpecs { public static Specification<customer> isLongTermCustomer() { return (root, query, builder) -> builder.lessThan(root.get("dateField"), new LocalDate().minusYears(2)); } public static Specification<customer> hasSalesOfMoreThan(MonetaryAmount value) { return (root, query, builder) -> { // Build query here }; } }</customer></customer>
您然后可以使用这些规范来构建动态查询:
List<customer> customers = customerRepository.findAll(CustomerSpecs.isLongTermCustomer());</customer>
组合规范
可以使用逻辑运算符(and、or)组合规范。这允许您构建复杂的搜索条件。
MonetaryAmount amount = new MonetaryAmount(200.0, Currencies.DOLLAR); List<customer> customers = customerRepository.findAll( where(CustomerSpecs.isLongTermCustomer()).or(CustomerSpecs.hasSalesOfMoreThan(amount)) );</customer>
创建复杂规范
规范可用于定义基于多个字段的复杂搜索条件。以下示例演示了使用各种过滤选项搜索正在进行的工作项的规范:
public class WorkInProgressSpecification { public static Specification<workinprogress> findByCriteria(final SearchCriteria searchCriteria) { return new Specification<workinprogress>() { @Override public Predicate toPredicate( Root<workinprogress> root, CriteriaQuery> query, CriteriaBuilder cb) { List<predicate> predicates = new ArrayList(); if (searchCriteria.getView() != null && !searchCriteria.getView().isEmpty()) { predicates.add(cb.equal(root.get("viewType"), searchCriteria.getView())); } // Other search criteria checks... return cb.and(predicates.toArray(new Predicate[] {})); } }; } }</predicate></workinprogress></workinprogress></workinprogress>
结论
规范为构建提供了灵活且可扩展的解决方案Spring Data JPA 中带有可选字段的动态查询。通过利用规范,您可以避免静态查询方法的限制,并根据您的业务需求轻松创建复杂的搜索条件。
以上是如何使用规范构建具有任意 AND 子句的动态 Spring Data JPA 查询?的详细内容。更多信息请关注PHP中文网其他相关文章!

ByteCodeachievesPlatFormIndenceByByByByByByExecutedBoviratualMachine(VM),允许CodetorunonanyplatformwithTheApprepreprepvm.Forexample,Javabytecodecodecodecodecanrunonanydevicewithajvm

Java不能做到100%的平台独立性,但其平台独立性通过JVM和字节码实现,确保代码在不同平台上运行。具体实现包括:1.编译成字节码;2.JVM的解释执行;3.标准库的一致性。然而,JVM实现差异、操作系统和硬件差异以及第三方库的兼容性可能影响其平台独立性。

Java通过“一次编写,到处运行”实现平台独立性,提升代码可维护性:1.代码重用性高,减少重复开发;2.维护成本低,只需一处修改;3.团队协作效率高,方便知识共享。

在新平台上创建JVM面临的主要挑战包括硬件兼容性、操作系统兼容性和性能优化。1.硬件兼容性:需要确保JVM能正确使用新平台的处理器指令集,如RISC-V。2.操作系统兼容性:JVM需正确调用新平台的系统API,如Linux。3.性能优化:需进行性能测试和调优,调整垃圾回收策略以适应新平台的内存特性。

javafxeffectife addressEddressEndressInconSiscies uningies uningusing inaplatform-agnosticsCenegraphandCssStyling.1)itabstractsplactsplatsplatsplatsplatformsthercensthascenegenceenceNaSceneGraph,确保ConsistSistEntertRenderingRenderingRenderingRenderingAccomWindows,MacOs,MacOS,MacOS,andlinux.2)

JVM的工作原理是将Java代码转换为机器码并管理资源。1)类加载:加载.class文件到内存。2)运行时数据区:管理内存区域。3)执行引擎:解释或编译执行字节码。4)本地方法接口:通过JNI与操作系统交互。

JVM使Java实现跨平台运行。1)JVM加载、验证和执行字节码。2)JVM的工作包括类加载、字节码验证、解释执行和内存管理。3)JVM支持高级功能如动态类加载和反射。

Java应用可通过以下步骤在不同操作系统上运行:1)使用File或Paths类处理文件路径;2)通过System.getenv()设置和获取环境变量;3)利用Maven或Gradle管理依赖并测试。Java的跨平台能力依赖于JVM的抽象层,但仍需手动处理某些操作系统特定的功能。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

Dreamweaver CS6
视觉化网页开发工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。