1、 HQL是面向对象的查询语言,HQL总的对象名是区分大小写的,HQL中查询的是对象而不是元素,并且支持多态。其主要通过Query来操作—创建方式:
Query q=session.createQuery(hql);
2、 HQL查询语句(例)
a) from User user where user age=20;查询年龄为20的人
b) from User user where user age between 20 and 30; 查询年龄为20或30的人
c) “from User as user where user.name=:n“ where user.name=:n命名参数
3、例题:public static void query(String name){
Session s=null;
try{
s=HibernateUtil.getSession();
String queryString="from User as user where user.name=:n";//from +类---查询user表里的所有记录----查询字符串---hibernate的查询语言----HQL
//where user.name=:n命名参数
Query query=s.createQuery(queryString);
query.setString("n",name);
query.setFirstResult(3);
query.setMaxResults(2);
List<User> list=query.list();
for(User u:list){
System.out.println(u.getId()+":"+u.getName());
}
/*User user=(User) query.uniqueResult();//查询一行。结果集超过一行会拋异常
System.out.println(user.getId()+":"+user.getName()); */
}finally{
if(s!=null){
s.close();
}
}
}
3、 HQL与SQL的不同
a) sql面向数据库查询。hql面向对象查询
b) 查询语句’
i. hql:from后面跟 类名+类对象 where 后用对象的属性做条件。
ii. sql:from后面跟的是表名。where后用表中字段做条件
4、 注意:
a) HQL是面向对象的 而对象类的名称和属性都是大小写敏感的,所以HQL是大小写敏感的。
b) from子句
i. 单个参数查询:from User user where user.Name=?
ii. 多个参数查询;:Sreing hql=”from User as user where user.loginName=? and user.age=?”;
iii. 查询数量 “select count (*) from User”
iv. 查询记录分页。限制查询开始记录和最大查询条数
String hql=”from User user order by user.logInName”’;
int firstResult=50;int maxResults=50;
Query query=session.createQuery(hql);
query=query.setFirstResult(firstResult);
query =setMaxResults(maxResults);
c) 新增;构建新增对象调用session对象的save()方法
d) 更新:取得需要跟新的持久化对象后执行session的update()方法
e) 删除:取得某个对象后。调用session的delete()方法
f) eg:
public User findUserById(int id) { //按ID查找 Session session=null; try{ session =HibernateUtil.getSession();//调用 Class clazz=User.class; User user=(User) session.get(clazz,id); return user; }finally{ if(session!=null){ session.close(); } } } @Override public void findUserByName(String name) { //按名字查找 Session session=null; try{ session =HibernateUtil.getSession();//调用 String queryString="from User as user where user.name=:n"; Query query=session.createQuery(queryString); query.setString("n",name); List<User> list=query.list(); for(User u:list){ System.out.println(u.getId()+":"+u.getName()); } }finally{ if(session!=null){ session.close(); } } } @Override public void remove(User user) { //s删除 Session session =null; Transaction tx=null; try{ session =HibernateUtil.getSession(); tx=session.beginTransaction(); session.delete(user); tx.commit(); }catch(HibernateException ex){ if(tx!=null){ tx.rollback(); } }finally{ if(session!=null){ session.close(); } } } @Override public void saveUser(User user) { //新增 Session session=null; Transaction tx=null; try{ session =HibernateUtil.getSession();//调用 tx=session.beginTransaction(); session.save(user); tx.commit(); }catch(HibernateException ex){ if(tx!=null){ tx.rollback();//回滚事物 } }finally{ if(session!=null){ session.close(); } } } @Override public void updateUser(User user) { // TODO Auto-generated method stub //跟新 Session session = null; Transaction tx=null; try{ session =HibernateUtil.getSession(); tx=session.beginTransaction(); session.update(user); tx.commit(); }catch(HibernateException ex){ if(tx!=null){ tx.rollback();//回滚事物 } }finally{ if(session!=null){ session.close(); } } }