hibernatehql深度历险

hibernatehql深度历险

ID:34723229

大小:55.78 KB

页数:6页

时间:2019-03-10

hibernatehql深度历险_第1页
hibernatehql深度历险_第2页
hibernatehql深度历险_第3页
hibernatehql深度历险_第4页
hibernatehql深度历险_第5页
资源描述:

《hibernatehql深度历险》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、HibernateHQL深度历险传统的SQL语言采用的是结构化的查询方法,而这种方法对于查询以对象形式存在的数据却无能为力。幸运的是,Hibernate为我们提供了一种语法类似于SQL的语言,Hibernate查询语言(HQL),和SQL不同的是,HQL是一种面向对象的查询语言,它可以查询以对象形式存在的数据。因此,本文就HQL如何工作以及如何使用HQL展开了深入的讨论。SQL本身是非常强大的。当SQL的这种强大和处理面向对象数据的能力相结合时,就产生了HQL。和SQL一样,HQL提供了丰富的查询功能,如投影查询、聚合函数、分组和约束

2、。任何复杂的SQL都可以映射成HQL。本文的第一部分将讨论HQL的简单用法。第二部分将讨论在HQL中如何根据上下文关系进行查询。在第三部分将以一个例子来说明如何在实际应用中使用HQL。进入HQL世界一个ORM框架是建立在面向对象的基础上的。最好的例子是Hibernate如何提供类SQL查询。虽然HQL的语法类似于SQL,但实际上它的查询目标是对象。HQL拥有面向对象语言的所有的特性,这其中包括多态、继承和组合。这就相当于一个面向对象的SQL,为了提供更强大的功能,HQL还提供了很多的查询函数。这些函数可以被分为四类:1.投影函数2.约

3、束函数3.聚合函数4.分组函数使用HQL可以建立简单的查询,也可以建立更复杂的查询。在本文中并不讨论那些非常复杂的查询,如含有子查询和很多连接的查询。本文只讨论连接两个表的查询。现在让我们开始接近HQL吧!投影如谓投影,就是一个可以访问的对象或对象的属性。在HQL中,可以使用from和select子句来完成这个工作。from子句返回指定的类的所有实例。如fromOrder将返回Order类的所有实例。换句话说,以上的查询相当于以下的SQL语句:select*fromorderfrom是最简单的查询子句。from后面可以跟一个或多个类名

4、(类名也可以带有别名)。为了得到Order和Product的所有实例,可以使用如下的查询:fromOrder,Product和类名一样,别名也可以在from后使用,如下代码如示:fromOrderaso,Productp当查询很复杂时,加入别名可以减少语句的长度。我们可以看看如下的SQL语句:selecto.*,p.*fromordero,productpwhereo.order_id=p.order_id我们可以很容易看出,上面的查询是一对多的关系。在HQL中相当于一个类中包含多个其它类的实例。因此,以上的SQL写成HQL就是:fr

5、omOrderasoinnerjoino.productsasproduct现在让我们考虑另外一个从表中得到指定属性的情况。这就是最常用的select子句。这在HQL中的工作方式和SQL中一样。而在HQL中,如果只是想得到类的属性的话,select语句是最后的选择。以上的SQL可以使用select子句改成如下的HQL语句:selectproductfromOrderasoinnerjoino.productsasproduct以上的HQL语句将返回Order中的所有Products实例。如果要得到对象的某一个属性,可以将HQL语句写成

6、如下的形式:selectproduct.namefromOrderasoinnerjoino.productsasproduct如果要得到多个对象的属性,可以将HQL语句写成如下形式:selecto.id,product.namefromOrderasoinnerjoino.productsasproduct接下来,我们将进入下一个议题。假设我们需要根据某些条件得到数据。那么以上所述的HQL语句将无法满足需求。为了达到这一目的,我们就要用到下面将要讨论的约束子句。约束从以上可知,投影返回的是所有的数据。但在大多数时候我们并不需要这么多

7、数据。这就需要对数据进行过滤。在HQL中过滤数据的子句和SQL一样,也是where。它的语法类似于SQL,通过where子句,可以对行进行过滤。我们可以看看下面的SQL语句:select*fromorderswhereid=‘1234’这条查询语句返回了id等于1234的所有的字段。和这条SQL对等的是下面的HQL语句:selectofromOrderowhereo.id=’1234’从以上两条语句可以看出,它们的where子句非常相似。而它们唯一的不同是SQL操作的是记录,而HQL操作的是对象。在HQL中,除了where子句可以过滤

8、数据外,having子句也可以做到这一点(关于having子句的详细内容我将在分组部分讨论)。投影和约束是两个基本的操作,这两个操作再加上聚合函数的话,那HQL将变得更加强大。下面我们就来讨论什么是聚合。聚合上述的查询都

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。