`
wangzhen5
  • 浏览: 80780 次
  • 性别: Icon_minigender_1
  • 来自: 河南省
社区版块
存档分类
最新评论

HQL语句的更新和删除

阅读更多
HQL语句的更新和删除
1.实体的更新和删除:
  在继续讲解HQL其他更为强大的查询功能前,我们先来讲解以下利用HQL进行实体更新和删除的技术。这项技术功能是Hibernate3的新加入的功能,在Hibernate2中是不具备的。

     比如在Hibernate2中,如果我们想将数据库中所有18岁的用户的年龄全部改为20岁,那么我们要首先将年龄在18岁的用户检索出来,然后将他们的年龄修改为20岁,最后调用Session.update()语句进行更新。

 

   在Hibernate3中对这个问题提供了更加灵活和更具效率的解决办法,如下面的代码:

  Transaction trans=session.beginTransaction();

  String hql=”update User user set user.age=20 where user.age=18”;

  Query queryupdate=session.createQuery(hql);

  int ret=queryupdate.executeUpdate();

  trans.commit();

  通过这种方式我们可以在Hibernate3中,一次性完成批量数据的更新,对性能的提高是相当的可观。同样也可以通过类似的方式来完成delete操作,如下面的代码:

  Transaction trans=session.beginTransaction();

  String hql=”delete from User user where user.age=18”;

  Query queryupdate=session.createQuery(hql);

  int ret=queryupdate.executeUpdate();

  trans.commit();

 2. 分组与排序

  A、Order by子句:

  与SQL语句相似,HQL查询也可以通过order by子句对查询结果集进行排序,并且可以通过asc或者desc关键字指定排序方式,如下面的代码:

  from User user order by user.name asc,user.age desc;

  上面HQL查询语句,会以name属性进行升序排序,以age属性进行降序排序,而且与SQL语句一样,默认的排序方式为asc,即升序排序。

  B、Group by子句与统计查询:

  在HQL语句中同样支持使用group by子句分组查询,还支持group by子句结合聚集函数的分组统计查询,大部分标准的SQL聚集函数都可以在HQL语句中使用,比如:count(),sum(),max(),min(),avg()等。如下面的程序代码:

  String hql=”select count(user),user.age from User user group by user.age having count(user)>10 ”;

  List list=session.createQuery(hql).list();

  C、优化统计查询:

  假设我们现在有两张数据库表,分别是customer表和order表,它们的结构如下:

  customer

  ID varchar2(14)

  age number(10)

  name varchar2(20)

  order

  ID varchar2(14)

  order_number number(10)

  customer_ID varchar2(14)

  现在有两条HQL查询语句,分别如下:

  from Customer c inner join c.orders o group by c.age;(1)

  select c.ID,c.name,c.age,o.ID,o.order_number,o.customer_ID

  from Customer c inner join c.orders c group by c.age;(2)

  这两条语句使用了HQL语句的内连接查询(我们将在HQL语句的连接查询部分专门讨论),现在我们可以看出这两条查询语句最后所返回的结果是一样的,但是它们其实是有明显区别的语句

   (1)检索的结果会返回Customer与Order持久化对象,而且它们会被置于Hibernate的Session缓存之中,并且Session会负责它们在缓存中的唯一性以及与后台数据库数据的同步,只有事务提交后它们才会从缓存中被清除;而语句

   (2)返回的是关系数据而并非是持久化对象,因此它们不会占用Hibernate的Session缓存,只要在检索之后应用程序不在访问它们,它们所占用的内存就有可能被JVM的垃圾回收器回收,而且Hibernate不会同步对它们的修改。

  在我们的系统开发中,尤其是Mis系统,不可避免的要进行统计查询的开发,这类功能有两个特点:第一数据量大;第二一般情况下都是只读操作而不会涉及到对统计数据进行修改,那么如果采用第一种查询方式,必然会导致大量持久化对象位于Hibernate的Session缓存中,而且Hibernate的Session缓存还要负责它们与数据库数据的同步。而如果采用第二种查询方式,显然就会提高查询性能,因为不需要Hibernate的Session缓存的管理开销,而且只要应用程序不在使用这些数据,它们所占用的内存空间就会被回收释放。

  因此在开发统计查询系统时,尽量使用通过select语句写出需要查询的属性的方式来返回关系数据,而避免使用第一种查询方式返回持久化对象(这种方式是在有修改需求时使用比较适合),这样可以提高运行效率并且减少内存消耗。㊣真正的高手并不是精通一切,而是精通在合适的场合使用合适的手段。

分享到:
评论

相关推荐

    hql语句大全

    以下是对标题和描述中所提到的HQL语句的详细说明: 1. 实体查询: HQL的基本查询形式是`from 类名`,这将返回该类的所有实例,包括其子类。例如,`from TUser`将获取所有TUser对象。如果TUser类有外键,不指定特定...

    HQL语句大全

    ### HQL语句大全:深入理解与应用 #### 概述 HQL(Hibernate Query Language)是Hibernate框架中用于查询数据库的一种面向对象的查询语言。它允许开发人员以面向对象的方式编写查询,而不是直接使用SQL。HQL支持...

    常用的HQL语句下载

    以下是一些常用HQL语句的使用与说明: 1. **HQL更新语句**: 更新操作允许您修改数据库中的对象属性。在示例中,第4行的HQL语句`update PhUser set realName=?`用于更新`PhUser`表中所有记录的`realName`字段。第5...

    HQL语句详解Select/update/deletefromwhere...

    需要注意的是,在Hibernate中查询时,如果实体之间存在继承关系(如`Employee`类继承自`HourlyEmployee`和`SalariedEmployee`),则可以通过类似`"from Employee"`这样的HQL语句来查询基类`Employee`的所有子类实例...

    HQL批量插入、更新和删除

    例如,要删除所有状态为“无效”的用户记录,可以执行如下HQL语句: ```java String hql = "DELETE User WHERE status = :status"; Query query = session.createQuery(hql); query.setParameter("status", ...

    Hibernate HQL查询语句总结.docx

    Hibernate HQL 查询语句总结 Hibernate HQL 查询语句是 Hibernate 框架中的一种查询语言,它提供了更加丰富的和灵活的查询特性,...使用 HQL 语句可以灵活地进行实体的查询、更新和删除操作,提高了开发效率和性能。

    hql语句 使用大全

    ### HQL语句使用大全 HQL(Hibernate Query Language)是一种面向对象的查询语言,它提供了灵活而强大的数据检索方式,使开发人员能够更高效地与数据库交互。本文将详细介绍HQL的基本用法及高级特性。 #### 1. ...

    Hql语句注意事项总结

    一种方法是动态构建Hql语句,将数组元素拼接成一个逗号分隔的字符串,然后在`in`子句中使用这个字符串。例如,`id in ('1','2','3')`。另一种方法是使用Hibernate的参数绑定功能,直接将数组作为参数传递,Hibernate...

    常用的HQL语句!!!!

    以下是一些常见的HQL语句及其用法: 1. **HQL更新**: 更新操作通常涉及到设置对象的属性并保存更改。例如,以下HQL语句用于将`PhUser`类中的某个用户的`realName`属性改为"小李想": ```java String hql = ...

    hql批量删除

    下面将详细介绍HQL在批量删除和批量插入数据方面的知识点。 批量删除数据: 在Hibernate中,如果要批量删除数据,使用Session的delete()方法来删除每一个对象将是非常低效的,尤其是当要删除的对象数量很多时。为此...

    hibernate 中HQL语句查询学习笔记

    ### Hibernate中HQL语句查询学习笔记 #### HQL基础 **HQL**(Hibernate Query Language)是Hibernate框架推荐使用的查询语言,它提供了一种面向对象的方式来查询数据库,支持多种复杂的查询操作,如继承、多态及...

    HQL语句(结合实例)

    它类似于SQL语言,但与SQL不同的是,HQL主要关注于对象的获取,而非直接进行数据库层面的更新、删除或插入等操作。HQL的一大特点是它在运行时才被解析执行,这使得HQL能够更好地适应对象模型与关系型数据库之间的...

    hibernate hql语句

    #### 完整的HQL语句格式 一个完整的HQL查询语句格式如下: ``` Select/update/delete … from … where … group by … having … order by … asc/desc ``` - **Select**: 查询指定字段或对象。 - **Update/...

    hql语句查询

    HQL支持基本的查询操作如选择、更新、删除等,并且可以方便地进行对象之间的关联查询。 #### 二、HQL语句的基本结构 HQL语句的基本结构通常包括以下几个部分: 1. **SELECT**:指定要查询的数据。 2. **FROM**:...

    HQL.pdf数据查询语句

    在上述代码中,`from User`是HQL语句,它将会返回User实体对应的数据库表中的所有记录。 另外,也可以指定类的完全限定名来进行查询: ```java Query query = session.createQuery("from com.vo.User"); ``` 注意,...

    超级详细的hql查询语句教程

    可以通过映射文件预先定义HQL语句,便于复用: ```xml SELECT s FROM Student s WHERE s.sname = :name ``` #### 四、HQL的嵌套子查询 ##### 4.1 嵌套子查询的概念 嵌套子查询是指在主查询中包含另一个查询的...

    hql的增删改查

    - 构造HQL字符串,其中包含计数表达式和条件语句。 - 使用`setParameter()`方法设置参数。 - `uniqueResult()`方法执行查询并返回单个结果。 - 转换结果类型为`Integer`并返回。 #### 八、小结 通过上述示例,我们...

    hql.rar_HQL_Hibernate查询_登录的hql代码

    hibernate源码中的hql语句代码,添加,删除,修改,查询;hibernate源码中的hql语句代码,添加,删除,修改,查询

    HQL简易介绍(DOC文档)

    在Hibernate3中,HQL引入了更新和删除操作,使得可以直接对数据库进行批量操作,提高效率。例如: - 更新操作: ```java Transaction trans = session.beginTransaction(); String hql = "update User user set user...

Global site tag (gtag.js) - Google Analytics