HQL的简单使用

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

           }

       }

    }


 

你可能感兴趣的:(HQL的简单使用)