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

2024-12-19 12:42:21
推荐回答(4个)
回答1:

hql="select * from user where id="+id;
Query q = session.createQuery(hql);
Lise list = q.list();
User user = (User)list.get(0);
你这里是按照id查找,如果id是User表的主键,那么他查找出来的只能是一个对象
这里需要注意的是query支持以select 开头的原生函数的查询。他查找出来的是瞬时态的
如果你想查找持久态的,可以用这个:
User user=(User)session.get(User.class,id);这个查找出来的是持久太的。

回答2:

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 是主键。

回答3:

你还要把你的异常信息贴出来.别人才知道出什么错,怎么改.

回答4:

错误是什么?user = list.get(0);