Hibernate 查询多个字段返回的list如何转为自定义对象
网上查到的代码:Stringhql="selectnewcom.domain.MyUser(name,passwd)fromUsers";Queryquery=sessi...
网上查到的代码:
String hql = " select new com.domain.MyUser(name,passwd) from Users";
Query query = session.createQuery(hql);
//默认查询出来的list里存放的是一个Object数组,但是在这里list里存放的不再是默认的Object数组了,而是MyUser对象了
List<MyUser> myUsers = query.list();
for(MyUser myUser : myUsers){
String name = myUser.getUsername();
String passwd = myUser.getPassword();
System.out.println(name + " : " + passwd);
}
根据这个代码我举一反三,写了如下代码:
public class VFidsFlightlegService extends HibernateDaoSupport implements
IVFidsFlightlegService {
public List<VFidsFlightleg> findiFids(Date FltDate, String FltNo, String Carrier) {
String sFltDate =TimeUtils.DateToString(FltDate);
String queryString="select legId, tailNo, intOrDom, arrAcLoc, deleteFlag, deptAirport,arrAirport, "+
"planArrTime, realArrTime from VFidsFlightleg where "+
"pdate = convert(datetime,'"+sFltDate+"',120) and flightNo = '"+FltNo+"' and carrier = '"+Carrier+"'";
System.out.println(queryString);
List<VFidsFlightleg> vFidsFlightleg= this.getHibernateTemplate().find(queryString);
System.out.println(vFidsFlightleg.get(0).getArrGate());
return vFidsFlightleg;
}
}
结果报错:
Exception in thread "main" java.lang.ClassCastException: [Ljava.lang.Object;
at com.ecc.parse.dao.VFidsFlightlegService.findiFids(VFidsFlightlegService.java:23) 展开
String hql = " select new com.domain.MyUser(name,passwd) from Users";
Query query = session.createQuery(hql);
//默认查询出来的list里存放的是一个Object数组,但是在这里list里存放的不再是默认的Object数组了,而是MyUser对象了
List<MyUser> myUsers = query.list();
for(MyUser myUser : myUsers){
String name = myUser.getUsername();
String passwd = myUser.getPassword();
System.out.println(name + " : " + passwd);
}
根据这个代码我举一反三,写了如下代码:
public class VFidsFlightlegService extends HibernateDaoSupport implements
IVFidsFlightlegService {
public List<VFidsFlightleg> findiFids(Date FltDate, String FltNo, String Carrier) {
String sFltDate =TimeUtils.DateToString(FltDate);
String queryString="select legId, tailNo, intOrDom, arrAcLoc, deleteFlag, deptAirport,arrAirport, "+
"planArrTime, realArrTime from VFidsFlightleg where "+
"pdate = convert(datetime,'"+sFltDate+"',120) and flightNo = '"+FltNo+"' and carrier = '"+Carrier+"'";
System.out.println(queryString);
List<VFidsFlightleg> vFidsFlightleg= this.getHibernateTemplate().find(queryString);
System.out.println(vFidsFlightleg.get(0).getArrGate());
return vFidsFlightleg;
}
}
结果报错:
Exception in thread "main" java.lang.ClassCastException: [Ljava.lang.Object;
at com.ecc.parse.dao.VFidsFlightlegService.findiFids(VFidsFlightlegService.java:23) 展开
5个回答
展开全部
String hql = " select new com.domain.MyUser(name,passwd) from Users";
Query query = session.createQuery(hql);
伱知道别人写这句hql语句有什么前提条件吗?
或者需要注意些什么吗?
伱写出那样的语句还叫举一反三, 真搞不懂.
Query query = session.createQuery(hql);
伱知道别人写这句hql语句有什么前提条件吗?
或者需要注意些什么吗?
伱写出那样的语句还叫举一反三, 真搞不懂.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
select legId, tailNo, intOrDom, arrAcLoc,deleteFlag,deptAirport,arrAirport planArrTime,realArrTime from VFidsFlightleg
返回的时数组类型 不是VFidsFlightleg 对象;如果你想获取VFidsFlightleg类型的对象就这样写HQL
from VFidsFlightleg
返回的时数组类型 不是VFidsFlightleg 对象;如果你想获取VFidsFlightleg类型的对象就这样写HQL
from VFidsFlightleg
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
(VFidsFlightleg)vFidsFlightleg.get(0)再强换一下啊。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
(VFidsFlightleg)vFidsFlightleg.get(0)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询