3

我有使用 Hibernate 来管理数据库内容的工作 .jsp webapp。随着 webapp 的及时增长,我现在面临服务器上的内存问题。所以我需要稍微重写一下以减少内存消耗。

我的代码如下:

@Table(name="items")
public class Items implements Serializable {

  @Id
  @GeneratedValue
  @Column(name="ID")
  private long id;

  @Column(name="Name", nullable=false)
  private String name;

  @Column(name="Image", nullable=true, length=1048576)
  private byte[] image;

  @Column(name="Text", nullable=true, columnDefinition="TEXT")
  private String text;

  @Column(name="AvailablePieces", nullable=true)
  private int storedAmount;

  @Column(name="Price", nullable=true)
  private int price;

  @ManyToOne
  @JoinColumn(name="colorId")
  private ItemColors color;

  @OneToMany(mappedBy = "key.item")
  @Cascade(CascadeType.ALL)
  Set<Orders_Items> orderItems = new HashSet<Orders_Items>();

....

}

和 SELECT 是

@NamedQuery(itemsByName",
    query = "* FROM Items i WHERE (i.name LIKE '%' || :iname || '%')"
),

问题是,一个常见的用法是一次获取约 500 条记录,而只需要大约 10-15 条记录来显示其图像。

有没有办法告诉 Hibernate 在一个 SELECT 中选择除 Image 之外的所有列,然后在计算需要其图像的项目以执行另一个 SELECT 以检索图像时(类似于“SELECT i.image FROM Items i WHERE i .id = :id")?

换句话说:选择特定列(包括@ManyToOne 映射列)的正确语法是什么——它会为“SELECT i.color FROM ...”之类的东西抛出 ClassCastException?

4

1 回答 1

3

使用投影功能:

如何使用条件返回具有选定列的实体

另一种是做延迟获取:

http://docs.jboss.org/hibernate/orm/3.3/reference/en-US/html/performance.html#performance-fetching-lazyproperties

于 2013-08-08T21:32:32.157 回答