HQL语句 hibernate 怎么实现 dao类中的按照id(int型)的查找

//------------------用id查找用户----------------------------publicUserfindByID(intid){//创建... //------------------用id查找用户----------------------------
public User findByID(int id) {
//创建Session
Session session = HibernateUtil.getSession();

//使用HQL查询
String hql = "from User WHERE id =?";

//使用Query方法查询
Query q = session.createQuery(hql);
q.setInteger(0, id);

//查询结果保存到list中
List list = q.list();
User user = null;

//遍历是否存在该id的会员,如果存在则输出
Iterator iter = list.iterator();
if(iter.hasNext()){
user = (User) iter.next();
}

//关闭session
HibernateUtil.closeSession(session);
return user;
}
哪位大虾帮我看看上面的程序到底出在哪里?拜谢了
展开
 我来答
百度网友117c93d
推荐于2017-09-10 · 超过10用户采纳过TA的回答
知道答主
回答量:22
采纳率:0%
帮助的人:29.5万
展开全部
hql="select * from user where id="+id;
Query q = session.createQuery(hql);
Lise<User> list = q.list();
User user = (User)list.get(0);
你这里是按照id查找,如果id是User表的主键,那么他查找出来的只能是一个对象
这里需要注意的是query支持以select 开头的原生函数的查询。他查找出来的是瞬时态的
如果你想查找持久态的,可以用这个:
User user=(User)session.get(User.class,id);这个查找出来的是持久太的。
whw378
2012-05-08 · 超过53用户采纳过TA的回答
知道小有建树答主
回答量:258
采纳率:0%
帮助的人:179万
展开全部
List list = q.list();
User user = null;

//遍历是否存在该id的会员,如果存在则输出
Iterator iter = list.iterator();
if(iter.hasNext()){
user = (User) iter.next();
}

你这里的意思是,你想把list 转为User 类型 ,你查询的方法不对。

public Book getBook(String id) {
Session session=hibernateTemplate.getSessionFactory().openSession();
Transaction transaction= session.beginTransaction();
Book book=(Book) session.get(Book.class, id);
transaction.commit();
session.close();
return book;

但是要求 id 是主键。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
zhanngle
2012-05-07 · TA获得超过395个赞
知道小有建树答主
回答量:129
采纳率:100%
帮助的人:104万
展开全部
你还要把你的异常信息贴出来.别人才知道出什么错,怎么改.
追问
是运行异常,只是定位到这个方法的Query q = session.createQuery(hql);的这一行上,具体我也不太清楚。
追答
根据你的回复,我觉得90%是你的hbm文件配制有问题.
就是你的User类配制有问题.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友2ce7c21
2012-05-07 · TA获得超过394个赞
知道小有建树答主
回答量:258
采纳率:100%
帮助的人:157万
展开全部
错误是什么?user = list.get(0);
追问
亲,改过来。错误依然存在!请问这里的q.setInteger(0, id);会不会有问题?
追答
query.setParameter(0, id);
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式