HQL的语法比较简单,与普通SQL的区别之处是针对对象的不同,在查询语句中将sql中的表名替换成了sql中的持久化类名,因为hibernate机制是基于对象进行查询的。
不带参数的查询,语句是“from POJO”的形式,其中POJO即为持久化类名称
Query query=session.createQuery("from User");
带参数的查询
接口Query提供了对命名参数、JDBC风格的(?)两种参数的绑定方法。
命名参数在查询字符串中是形如name的标识符。
命名参数的优点:
1、命名参数与其在查询串中出现的顺序无关。
2、它们可在同一查询串中多次出现。
3、它们本身是自我说明的。
命名参数的使用格式是 :username /* username这里泛指命名参数名 */
赋值采用: Query的setXXX()f方法。
/* 这是使用一个命名参数username,然后给命名参数设置值为“admin”的例子*/
Query query=session.createQuery("from User where username=:username"); query.setString("username","admin");
/* 使用集合类型的命名参数的例子 */
List names=new ArrayList(); names.add("admin"); names.add("test"); Query query=session.createQuery("from User where username in (:nameList)"); query.setParameterList("nameList",names);
hibernate使用问号参数时与JDBC不同,hibernate对参数从0开始计数。JDBC应该是从0开始的
Query query=session.createQuery("from User where username=?");
query.setString(0,"admin");
在HQL语句中可以设置多个问号参数,之后按照"0、1、2、3...”的序号形式来设置各个参数的值。
取读query中的值:
1、将query中的值转换成list然后进行后面的操作
query.list()方法。
demo:
public List<Person> hqlquerylist(String hql){ Session session=HibernateSessionFactory.getSession(); Transaction tx=session.beginTransaction(); List<Person> p = null; try{ Query query=session.createQuery(hql); p=query.list(); tx.commit(); }catch(Exception e){ e.printStackTrace(); tx.rollback(); } return p; }