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;
    }
View Code

相关文章:

  • 2022-12-23
  • 2021-07-28
  • 2021-10-25
  • 2021-06-05
猜你喜欢
  • 2021-10-17
  • 2021-10-10
  • 2021-12-21
  • 2022-02-02
  • 2022-12-23
  • 2021-11-28
  • 2021-05-17
相关资源
相似解决方案