gpt4 book ai didi

java - 非抽象对象上的 JPA 延迟加载

转载 作者:行者123 更新时间:2023-12-01 13:14:57 27 4
gpt4 key购买 nike

我正在尝试“调整”我的应用程序,也许可以加快速度。我使用 hibernate 作为 JPA 实现,并且有一个名为 Product 的实体。它由名称、描述、id 和图像组成,在类定义中表示为 byte[]。

在“Web 层端”,我有一个 servlet(ProductServlet),其 GET 方法发出并从数据库检索所有 Product 对象的列表,将它们作为属性放入请求中,然后转发到 JSP ,其中产品显示在表格中。

为了显示图像,(基于我在 JSP 中将 byte[] 数据显示为图像时发现的一些建议)我有一个单独的 servlet(ImageServlet),其 GET 方法返回产品的 JPG 编码图像,该产品ID传入。

我的问题是,有没有办法让图像(byte[])“延迟加载”,这样当我向 ProductServlet 发出初始请求时,返回的产品列表没有图像( byte[]) 属性被检索,直到我显式调用product.getImage()(我假设这就是延迟加载的工作原理)。

这样,最初调用后端数据库来获取产品列表会更快,因为不会返回所有 byte[] 数据,然后当我需要获取时只获取 byte[] 图像部分图像(使用 ImageServlet)。

我试图在我的 byte[] 图像属性上设置延迟获取属性,但它说这是不允许的,我猜是因为它是一个标准的 Java 类,而不是我自己定义的抽象类。

最佳答案

在 JPA 2 中,您将列标记为 @Basic(fetch=FetchType.LAZY)。如果 JPA 1,您可以创建一个 SimpleProduct 实体,该实体仅包含基本信息,不包含图像。但请注意,即使您的数据库不返回列值(它不在 select 子句中),它也会从磁盘读取。这是成本。

我将保持第一步不变。加载所有产品后,我会将图像放入缓存中(您可以使用简单的 Guava cache ),并且 ImageServlet 应该从缓存中读取。使其成为短生命周期缓存(例如 15 秒),并提供一个加载器,以防图像不知何故不在缓存中,然后访问数据库。

关于java - 非抽象对象上的 JPA 延迟加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22542404/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com