Spring HATEOAS,如何处理到实体的转换链接而不会淹没数据库

问题描述

我正在使用Spring Boot 2.3,Spring Data REST,Spring HATEOAS,Hibernate。 让我们考虑一个简单的用例,例如用户在Web客户端中创建发票或仓库的库存清单。当用户提交表单时,可以发送数百行或几行,并且这些行可以具有指向其他实体的链接

例如,在发票的情况下,每行都可以有一个产品参考,该产品参考将作为链接传递给服务器。

Spring使用Repository链接转换为实体。我的观点是,对于每一行,都会运行一个查询获取产品。 这意味着插入过程中所有操作都会非常缓慢(n + 1个选择问题)。

可能我错过了逻辑方面的知识,但是我没有看到具体的示例集中在如何处理大量翻译链接->实体上。

您对此有任何提示吗?

解决方法

关于链接的实体将返回到服务器时将创建的许多实体,您的观点是吗? Hibernate(以及spring)具有延迟加载机制-https://blog.ippon.tech/boost-the-performance-of-your-spring-data-jpa-application/,因此只会填充必要的实体。如果我想念您的问题,请纠正我。