动态实例化查询结果

本文介绍了一种使用Hibernate进行动态实例化查询的方法,通过构造特定的查询语句来获取所需的数据,并将其封装到自定义的CustomerRow类中。这种方法不需要目标类成为持久化类,简化了对象-关系映射。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

动态实例化查询结果
摘自《精通Hibernate》一书
package mypack;

import java.io.Serializable;
public class CustomerRow implements Serializable {

private Long id;

private String name;

private String orderNumber;

public CustomerRow(Long id,String name, String orderNumber) {
this.id=id;
this.name = name;
this.orderNumber = orderNumber;
}

public Long getId() {
return this.id;
}

public void setId(Long id) {
this.id = id;
}

public String getName() {
return this.name;
}

public void setName(String name) {
this.name = name;
}

public String getOrderNumber() {
return this.orderNumber;
}

public void setOrderNumber(String orderNumber) {
this.orderNumber = orderNumber;
}

}


Iterator it = serssion.createQuery("select new mypack.CustomerRow(c.id, c.name, o.orderNumber) from Customer c join c.orders o where o where o.orderNumber like 'T%'").list().iterator();
while(it.hasNext()){
CustomerRow row = (CustomerRow)it.next();
Long id = row.getId();
String name = row.getName();
....
}

CustomerRow类不需要是持久化类,因此不必创建它的对象-关系映射文件.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值