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;
}
哪位大虾帮我看看上面的程序到底出在哪里?拜谢了 展开
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;
}
哪位大虾帮我看看上面的程序到底出在哪里?拜谢了 展开
4个回答
展开全部
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);这个查找出来的是持久太的。
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);这个查找出来的是持久太的。
展开全部
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 是主键。
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 是主键。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你还要把你的异常信息贴出来.别人才知道出什么错,怎么改.
追问
是运行异常,只是定位到这个方法的Query q = session.createQuery(hql);的这一行上,具体我也不太清楚。
追答
根据你的回复,我觉得90%是你的hbm文件配制有问题.
就是你的User类配制有问题.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
错误是什么?user = list.get(0);
追问
亲,改过来。错误依然存在!请问这里的q.setInteger(0, id);会不会有问题?
追答
query.setParameter(0, id);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询