本文为博主原创,允许转载,但请声明原文地址:http://www.coselding.cn/blog/8/8-142.html HQL语法结构类SQL语句, Query query = session.createQuery(String HQL); 通过一个HQL查询语句得到一个Query的对象,可以通过这个对象得到HQL语句的查询结果集 查
本文为博主原创,允许转载,但请声明原文地址:http://www.coselding.cn/blog/8/8-142.html
-
HQL语法结构类似SQL语句,
-
Query query = session.createQuery(String HQL); 通过一个HQL查询语句得到一个Query的对象,可以通过这个对象得到HQL语句的查询结果集
-
查询支持内链接,左右外连接,支持对Hibernate实体类的直接查询,以及对A实体类中的其他B实体类成员直接用”.”来作为A实体类的列来调用(已设置关联关系);
-
From,select,where,order by,group by,子查询都和SQL一样,具体查询文档
-
?序号是从0位开始的
-
Query.list的数据用完才能session.close()
-
Query支持正常的SQL、HQL、EJBQL。功能强弱:NativeSQL>HQL>EJBQL>QBC>QBE。
-
HQL占位符:”:参数名”或者”?”,使用setInteger等方法直接替换占位符中的参数。
-
分页:setMaxResults:设置每页条数,setFirstResult设置从第几条开始。
-
可以像SQL一样返回每个列的属性值,每个属性值以Object返回,形成一个Object数组。也可以把这些返回的列值合成一个临时的包装对象进行保存,在HQL写”new 类限定名”。
-
HQL用”join”进行导航连接,join t.topic不能用join Topic,因为要设定t中的哪个对象和Topic进行连接。
-
query.uniqueResult():返回查询唯一对象。
-
count(*)返回long类型,用query.uniqueResult()。
-
聚合函数、between…and、in、not null、is empty、is not empty、like、exists、not exists。Exists的执行效率比in高。
-
EJBQL常用函数,变大小写、连接字符串、去空格、平均数、求和等函数。(不重要)
-
日期直接用>、
-
group by、having、子查询、ALL函数。
-
NameQuery:将查询命名起来,之后直接用key调用,@NameQueries定义命名查询,将查询语句集中化管理。
-
createSQLQuery():使用正常的SQL语句查询,返回SQLQuery,@NameNativeQueries。
-
QBC(Query By Criterial):Criteria约束集合,用Restrictions产生查询约束条件,即where后面的子句,相当于把SQL语句变得面向对象化!!!DetachedCriteria:创建好再绑定session的对象,可以脱离session管理。
-
QBE(Query By Example):Example e = Example.create(Object obj);产生一个约束条件对象,可以当作Criteria的约束对象加入进去,使面向对象更彻底。
本文为博主原创,允许转载,但请声明原文地址:http://www.coselding.cn/blog/8/8-142.html