在做SSH框架整合时,在进行DAO操作时。调用login()方法。运行时在firebug里报错user is not mapped。
login()方法:
public User login(User user) {
Tuser t = userdao.get("from tuser t where t.name=? and t.pwd = ?",
new Object[]{user.getName(),Encrypt.e(user.getPwd())});
if(t != null){
return user;
}
return null;
}
get()方法如下:
public T get(String hql, Object[] params) {
Query q = this.session.getCurrentSession().createQuery(hql);
if(params != null && params.length > 0){
for(int i = 0; i < params.length; i++){
q.setParameter(i, params[i]);
}
}
List<T> l = q.list();
System.out.println("hql"+l.size());
if(l != null && l.size() > 0){
return l.get(0);
}
return null;
}
上面的语句出错时因为自己写了HQL的语句,其中我写的语句是:
"from tuser t where t.name=? and t.pwd = ?"
但是在HQL语句中表名应该是ORM映射的**类名**,而不是你在数据库中的表名。
所以将HQL语句中的user的表名改为User即可,改后如下:
"from Tuser t where t.name=? and t.pwd = ?"
只要将表明换成ORM映射的类名就可以了
在次运行就不会报没有 xxx is not mapped的错了。