gpt4 book ai didi

java - 在带有外国的表上选择除一列以外的所有列

转载 作者:行者123 更新时间:2023-11-30 09:19:03 25 4
gpt4 key购买 nike

我有一个正在运行的 .jsp webapp,它使用 Hibernate 来管理数据库内容。随着 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.id = :id")?

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

最佳答案

关于java - 在带有外国的表上选择除一列以外的所有列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18134158/

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