HQL的简单使用

来源:互联网 发布:淘宝业务模式 编辑:程序博客网 时间:2024/06/11 23:55

 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();           }       }    }


 

原创粉丝点击