取查询结果的几种方法

List:
A. 查询语句中只查一个字段
[quote]Session session = HibernateSessionFactory.currentSession();
Transaction transaction = session.beginTransaction();
Query query = session.createQuery([color=blue]"select e.name from Employee e"[/color]);
List list = query.list();
for (int i = 0; i < list.size(); i++) {
[color=blue]Object object = (Object)list.get(i);[/color]
String s = (String) object;
System.out.println(s);
}[/quote]
B. 查询语句中多于一个字段
[quote]Session session = HibernateSessionFactory.currentSession();
Transaction transaction = session.beginTransaction();
Query query = session.createQuery([color=blue]"select d.name, e.name from Department d, Employee e where d.id=e.department.id"[/color]);
List list = query.list();
for (int i = 0; i < list.size(); i++) {
Object[] object = (Object[])list.get(i);
String s = (String) object[0];
System.out.println(s);
}[/quote]

Iterator:
也看查询语句中的字段,
A 如果是查整个表,可以直接转换为对象。
[quote]HQL: from Department
for (Iterator iter = query.iterate(); iter.hasNext(); ) {
Department department = (Department) iter.next();
System.out.println(department.getName());
}[/quote]
B 如果字段为一个,直接用实际的字段类型转换。
[quote]HQL: select e.name from Employee e
for (Iterator iter = query.iterate(); iter.hasNext(); ) {
String s = (String) iter.next();
System.out.println(s);
}[/quote]
C 如果字段多于一个,先用Object[]取出,然后陆续用实际字段的名字转换。
[quote]HQL: select d.name, e.name from Department d, Employee e where d.id=e.department.id
for (Iterator iter = query.iterate(); iter.hasNext(); ) {
Object[] object (Object[]) inter.next();
String s = (String) object[0];
System.out.println(s);
}[/quote]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值