`

hibernate基础-HQL

阅读更多
在hql中关键字不区分大小写,但是属性和类名区分大不写

简单属性查询[重要]
1  单一属性查询,返回结果集属性列表,元素类型和实体类中相应的属性类型一致
 List students=session.createQuery("select name from Student").list();
            
for(Iterator iter=students.iterator();iter.hasNext();){
                String name
=(String)iter.next();
                System.out.println(name);
          }
2  多个属性查询,返回的集合元素是对象数组
  数组元素的类型和对应的属性在实体类中的类型一致
  数组的长度取决于select中属性的个数

 List students=session.createQuery("select id, name from Student").list();
            
for(Iterator iter=students.iterator();iter.hasNext();){
                Object[] obj
=(Object[])iter.next();
                System.out.println(obj[
0]+":"+obj[1]);
            }
3  对象化查询,可以采用hql动态实例化Student对象,此时list中为Student对象集合
   注意,必须有在实体类中有相应的构造方法
List students=session.createQuery("select new Student(id, name) from Student").list();
            
for(Iterator iter=students.iterator();iter.hasNext();){
                Student stu
=(Student)iter.next();
                System.out.println(stu.getId()
+":"+stu.getName());
            }
4  别名查询,可以使用as命名别名
 List students=session.createQuery("select s.id, s.name from Student as s").list();
            
for(Iterator iter=students.iterator();iter.hasNext();){
                Object[] obj
=(Object[])iter.next();
                System.out.println(obj[
0]+":"+obj[1]);
            }
5 实体属性
  setEntity();



实体对象查询[重要]


1 忽略select,返回Student对象的集合,可以忽略select
List students=session.createQuery("from Student").list();
            
for(Iterator iter=students.iterator();iter.hasNext();){
                Student stu
=(Student)iter.next();
                System.out.println(stu.getName()
+":"+stu.getCreateTime());
            }
2 使用别名,返回Student对象的集合,可以使用别名,两种方式都支持:空格或as
List students=session.createQuery("from Student s").list();
  List students
=session.createQuery("from Student as s").list();
  
for(.){.}
3 使用select,返回Student对象的集合,使用select用,必须使用别名
List students=session.createQuery("select s from Student as s").list();
  
for(.){.}
4 不支持select * from...这样的查询
[X]List students=session.createQuery("select * from Student s").list();//错误的[X]
5 使用query.iterate查询
  在默认情况下,使用query.iterate查询,有可能出现N+1问题
  所谓N+1是在查询的时候发出N+1条sql语句
  * 1:先发出查询id的sql
 * N:再依次发出根据id查询Student对象的sql
Iterator iter=session.createQuery("from Student").iterate();
            
while(iter.hasNext()){
                Student stu
=(Student)iter.next();
                System.out.println(stu.getName()
+":"+stu.getCreateTime());
            }
6 使用query.list查询,返回Student对象的集合
  在默认情况下list每次都会向数据库发出查询对象的sql,除非配置查询缓存,
  但list默认情况下不会利用缓存,而是每次发出sql
 在默认情况下,list会向缓存中放入数据,但不会利用数据
List students=session.createQuery("from Student").list();
    
for(.){.}
7 list和iterate的区别
  * list:在默认情况下每次都会向数据库发出sql,list会向缓存中放入数据,但不会利用缓存中的数据
  * iterate:在默认情况下会利用缓存中的数据,但缓存中不存在数据,有可能出现N+1问题


条件查询[重要]

* 方法链编程
 Query query=session.createQuery("select id,name from Student where name like ?");
            query.setParameter(
0"%1%");
            List students 
=query.list();
    
//等效于:
        List students=session.createQuery("select id,name from Student where name like ?")
                                       .setParameter(
0"%1%")
                                       .list();
1 拼字符串
  可以采用拼字符串的方式组织查询条件
List students=session.createQuery("select id,name from Student where name like '%1%'").list();
2 ?传递参数
  可以采用?占位符来传递参数,参数的索引从0开始,传递的参数值不用单引号引起来
  List students=session.createQuery("select id,name from Student where name like ?")
                                   .setParameter(
0"%1%")
                                   .list();
3 “:参数名” 传递参数
  可以采用“:参数名称”的方式传递参数,效果等同于?占位符方式
  List students=session.createQuery("select id,name from Student where name like :myname")
                                   .setParameter(
"myname""%1%")
                                   .list();
4 支持in,采用(:参数名)传递参数数组
  支持in,使用“(:参数名称)”的方式传递数组,用setParameterList()设置数组参数
  List students=session.createQuery("select id,name from Student where id in (:myids)")
                                   .setParameterList(
"myids"new Object[]{1,2,3,4,5,6})
                                   .list();
5 支持and和between
  List students=session.createQuery("select id,name from Student where name like :myname and id=:myid")
                                   .setParameter(
"myname""%1%")
                                   .setParameter(
"myid"12)
                                   .list();
    SimpleDateFormat sdf
=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    List students
=session.createQuery("select id,name from Student where createTime between ? and ?")
                                   .setParameter(
0, sdf.parse("2008-01-10 00:00:00"))
                                   .setParameter(
1, sdf.parse("2008-02-15 00:00:00"))
                                   .list();
6 在hql中可以使用数据库中的函数 
 不建议使用
  List students=session.createQuery("select id,name from Student where date_format(createTime,'%Y-%m')=?")
                                   .setParameter(
0"2008-02")
                                   .list();

原生sql查询

List students=session.createSQLQuery("select * from t_student).list();
  for(Iterator iter=students.iterator();iter.hasNext();){
                Object[] obj
=(Object[])iter.next();
                System.out.println(obj[
0]+":"+obj[1]);
            }

外置命名查询

  * 在映射文件中采用<query>标签来定义hql,可以在任何一个映射文件中,name属性名能重复
<query name="searchStudents">
            
<![CDATA[
                 select s from Student s where s.id<?
            
]]>
        
</query>
  * 在程序中采用session.getNameQuery()方法得到hql查询串
 List students=session.getNamedQuery("searchStudents")
                                           .setParameter(
010)
                                           .list();

查询过滤器

  * 在映射文件中定义过滤器参数
    <filter-def name="filtertest">
    
<filter-param name="myid" type="integer"/>
   
</filter-def>
  * 在类的映射中使用这些参数
    <class name="com.my.hibernate.Student">
    
<filter name="filtertest" condition="id &lt; :myid"/>
  
</class>
  * 在程序中起用过滤器,传入参数
    session.enableFilter("filtertest").setParameter("myid"10);
   List students
=session.createQuery("from Student").list();

分页查询[重要]

List students=session.createQuery("from Student")
                                       .setFirstResult(
0)
                                       .setMaxResults(
3)
                                       .list();
//setFirstResult()从0开始
//setMaxResults()每页显示多少条数据

对象导航查询,在hql中采用“.”进行导航[重要]

List students=session.createQuery("select  s.name from Student s where s.classes.name like '%1%'").list();

连接查询[重要]

  * 内连接
    List students=session.createQuery("select c.name,s.name from Student s join s.classes c")
                                 .list();
      
// inner可以省略
        List students=session.createQuery("select c.name,s.name from Student s inner join s.classes c")
                                 .list();
  * 外连接(左连接/右连接)
//左:
List students=session.createQuery("select c.name,s.name from Classes c left join c.students s").list();
//右:
List students=session.createQuery("select c.name,s.name from Classes c right join c.students s").list();

统计查询[重要]

List stu=(List)session.createQuery("select count(*) from Student").list();
// uniqueResult()查询单一值,返回Long类型
Long count=(Long)session.createQuery("select count(*) from Student").uniqueResult();
// 分组查询问
List students=(List)session.createQuery("select c.name,count(s) from Student s join s.classes c group by c.name order by c.name").list();


DML风格的查询

批量修改、删除、插入,可能会出现脏数据,尽量少用,和缓存不同步

session.createQuery("update Student s set s.name=? where s.id<?")
           .setParameter(
0"田田田")
           .setParameter(
15)
           .executeUpdate();


其他


is null, and, or, not, in, between
Restrictions.like("bookname","a",MatchMode.START);
关键字不区分大小写,类名区分大小写,类名不能用关键字,类名可以用全名

select s from Student s where s.name like '%李%'
select s from Student s where s.name like ?
query.setString(0,"%李%").list();
query.setEntity(classes);//对象实体参数
注意jdbc中perstmt参数从1开始
from Student s where s.id between :dd and :dr
query.setInt(dd,1);
query.setInt(dr,2);
select j from Tjd j,Tfw f where f.jd=j and fw.lxr='王先生'
select s from Strudent s,Classes c where s.classes=c //联表查询
分页
query.setFirstResult(0);//默认从0开始
query.setMaxResult(int size);

分享到:
评论

相关推荐

    Hibernate-HQL-查询-Query资料

    - "HQL查询语言.doc"可能包含HQL的基础语法和用法的介绍。 - "HQL查询.doc"可能深入探讨了更复杂的查询技巧和注意事项。 - "HQL语句(结合实例).doc"则可能提供了具体的查询示例,帮助读者更好地理解和应用HQL。...

    Hibernate-HQL.rar_HQL_hibernate hql

    本篇文档将深入探讨Hibernate中的HQL(Hibernate Query Language),一种面向对象的查询语言,它提供了与SQL类似的语法,但更贴近于面向对象的思维模式,使得开发者可以更加便捷地进行数据查询。 一、HQL简介 HQL是...

    hibernatetools-Update-4.1.1.Final_2013-12-08_01-06-33-B605.zip

    2. **HQL/SQL编辑器**:提供语法高亮和智能提示,支持HQL(Hibernate Query Language)和SQL的编写与调试。 3. **数据库连接管理**:方便地创建、编辑和测试数据库连接,支持多种数据库类型。 4. **逆向工程**:...

    hibernate-hql-testing-1.0.0.Alpha5.zip

    【标题】"hibernate-hql-testing-1.0.0.Alpha5.zip" 提供的是Hibernate框架的一个测试工具包,专注于HQL(Hibernate Query Language)的测试。Hibernate是Java领域中广泛使用的对象关系映射(ORM)框架,它允许...

    hibernate-hql 资料大全

    1. **find(String queryString)**: 这是最基础的HQL查询方法,接受一个HQL语句作为参数,返回所有匹配该查询的实体对象。例如,"from bean.User"会返回所有的User对象。 2. **find(String queryString, Object ...

    hibernate3.5.0-final下载链接

    - **HQL与Criteria API增强**:HQL(Hibernate Query Language)和Criteria API 在此版本中得到了显著增强,提供了更多的查询选项和灵活性。 - **EclipseLink集成**:虽然主要还是一个Hibernate版本,但该版本也考虑...

    hibernate-release-5.0.7.Final的所有jar包

    3. **hibernate-jpa-2.1-api**: 提供JPA 2.1的API接口,是Hibernate与JPA交互的基础。 4. **hibernate-validator**: Hibernate的验证框架,符合JSR-303/JSR-349标准,用于数据验证,确保输入数据的正确性。 5. **...

    hibernate-core-5.0.11.Final.jar

    Hibernate Core是Hibernate框架的基础部分,它包含了ORM的核心功能,如实体管理、事务处理、查询语言(HQL)等。`5.0.11.Final`版本是一个稳定且广泛使用的版本,提供了诸多改进和优化。 二、源码结构解析 `...

    hibernatetools-Update-4.1.1.zip

    此外,Hibernate Tools的可视化HQL和SQL编辑器也是其亮点。开发者可以通过直观的界面编写查询语句,实时查看结果,甚至进行调试。在新版本中,编辑器的性能得到提升,支持更多的语法高亮和智能提示,使开发者在编写...

    hibernate--- jar包

    7. **查询语言HQL和 Criteria API**: Hibernate提供了自己的查询语言HQL(Hibernate Query Language),类似于SQL,但面向对象。Criteria API则提供了一种类型安全的、基于对象的查询方式。 8. **性能优化**: ...

    Hibernate hibernate-core-1a8aca9.ta

    学习Hibernate,首先要掌握Java基础和基本的SQL知识,然后深入理解Hibernate的配置文件,如hibernate.cfg.xml,学会配置数据库连接、实体类映射等。接着,通过实践操作,了解Session、Transaction的使用,以及Query...

    hibernate3-2 官方jar包+api

    Hibernate 是一个著名的开源对象关系映射(ORM)框架...综上所述,"hibernate3-2 官方jar包+api"是学习和开发基于Hibernate 3.2的Java应用的基础资源,涵盖了ORM的核心概念和技术,帮助开发者更高效地管理数据库操作。

    hibernate-annotations-3.4.0.GA

    2. 数据库操作:使用Session的save()、update()、delete()方法进行CRUD操作,或者使用Criteria、HQL等查询语言进行复杂查询。 3. 关联映射:通过@ManyToOne、@OneToMany等注解定义实体之间的关联关系,实现对象的懒...

    hibernate-extensions-2.1.3.zip ,middlegen for hibernate

    - Criteria查询增强:允许更复杂的动态查询构建,超越了HQL(Hibernate查询语言)的限制。 - Cache管理:提供更细粒度的缓存控制,包括第二级缓存和查询缓存的优化。 - Batch处理:支持批量插入、更新和删除操作...

    hibernate-annotations-3.4.0.GA and hibernate-entitymanager-3.4.0.GA

    - HQL(Hibernate Query Language):类似于SQL,专门用于查询Hibernate实体的语句。 - QBC(Query By Criteria):基于Java对象的查询方式,提供构建查询条件的API。 通过以上讲解,我们可以看出`hibernate-...

    HibernateTools-3.2.4.rar

    除了上述主要功能外,HibernateTools还包含了一些实用小工具,如HQL查询编辑器、数据库浏览器等。这些工具使得开发者可以直接在工具内调试HQL语句,查看数据库表结构,从而提高开发效率。 总结起来,HibernateTools...

    hibernate-core 核心jar包

    `hibernate-core` jar包是使用Hibernate的基础,它包含了所有必要的类和接口,使得开发者能够集成ORM功能到Java应用中。通过理解和熟练使用Hibernate-Core,可以极大地提高数据库操作的效率和代码的可维护性。

    hibernate-distribution-3.3.2.GA-dist

    3. **查询语言HQL**:Hibernate Query Language(HQL)是一种面向对象的查询语言,类似于SQL,但更接近Java的语法,可以更方便地进行对象查询。 4. **Criteria查询**:提供了一种基于对象的查询方式,允许开发者...

    hibernate-release-4.2.4核心jar包

    在Hibernate 4.2.4版本中,其核心库包含了一系列关键的jar包,这些jar包构成了Hibernate功能的基础。下面我们将逐一剖析这些jar包的作用,以帮助读者深入理解Hibernate的核心机制。 首先,`hibernate-core-4.2.4....

Global site tag (gtag.js) - Google Analytics