亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Hibernate查詢語言:HQL

2019-11-18 13:55:30
字體:
來源:轉載
供稿:網友

  HQL:Hibernate Qusery Language,假如你已經熟悉它,就會發現它跟SQL非常相像。不過 你不要被表面的假象迷惑,HQL是面向對象的(OO,用生命的眼光看待每一個對象,他們是如此 鮮活)。假如你對java和SQL語句有一定了解的話,那么HQL對你簡直易如反掌,你完全可以利用在公車上的時間把握它。

以下從幾個方面進行慢慢深入:

1。大小些敏感
大家知道Query是對大小寫不敏感的,但是在HQL(前面提到它是OO的)中那么對象類的名稱和屬性確實大小寫敏感的(符合java編程語法)。
如:sElect cat.name from Cat as cat和select cat.name from Cat as cat是一樣的
但是:
sElect cat.name from CAT as cat和select cat.name from Cat as cat確實不一樣的。

2。from語句
最簡單的:
from eg.Cat
它只是簡單的返回所有eg.Cat的實例
通常我們此時會為eg.Cat其個別名,因為在query的其余部分可能會用到(參看上邊關于大小寫
敏感時的例子情形),如:
from eg.Cat as cat 這里as可以省略。
上邊只是單表查詢,多表的情況如下寫法:
from eg.Cat,eg.Dog
from eg.Cat as cat,eg.Dog as dog

3。join相關
(inner) join
left (outer) join
right (outer) join
full join
HQL同樣對SQL中的這些特性支持
下面插播一個小話題,關于上邊的那些特性,我一直都沒怎么用,今天既然說到這里,就想
把上邊的幾個特性的用法說一下,也算對自己的一個補充:
假設有兩個表:部門、員工,下面列舉一些數據:
員工(Employee):
ID Name DepNo
001 Jplateau 01
002 Jony 01
003 Camel 02
部門(Department):
ID Name
01 研發部
02 營銷部

在Hibernate中我們操縱的都是對象,所以我們操縱的是部門類和員工類
1).(inner) join
select employee.ID as id1,employee.Name as name1,department.ID as id2,department.Name
as name2 from Employee as employee join Department as department on employee.DepNo=
department.ID (注重到條件語句我用on 沒有用where)
那么執行結果是什么呢?
id1 name1 id2 name2
++++++++++++++++++++++++++++++++++++++
001 Jplateau 01 研發部
002 Jony 01 研發部

2).left (outer) join
select employee.ID as id1,employee.Name as name1,department.ID as id2,department.Name
as name2 from Employee as employee left join Department as department on employee.DepNo=
department.ID
那么執行結果又該是什么呢?
id1 name1 id2 name2
++++++++++++++++++++++++++++++++++++++
001 Jplateau 01 研發部
002 Jony 01 研發部
003 Camel null null
{就是說此時我要已第一個表的記錄多少為準,第二個表中沒有相應紀錄的時候填充null}
3). right (outer) join
select employee.ID as id1,employee.Name as name1,department.ID as id2,department.Name
as name2 from Employee as employee right join Department as department on employee.DepNo=
department.ID
那么執行結果又該是什么呢?
id1 name1 id2 name2
++++++++++++++++++++++++++++++++++++++
001 Jplateau 01 研發部
002 Jony 01 研發部
null null 02 營銷部
{就是說此時我要已第二個表的記錄多少為準,第一個表中沒有相應紀錄的時候填充null}

4。select語句
就是要確定你要從查詢中返回哪些對象或者哪些對象的屬性。寫幾個例子吧:
select employee form Employee as employee
select employee form Employee as employee where employee.Name like 'J%'
select employee.Name form Employee as employee where employee.Name like 'J%'
select employee.ID as id1,employee.Name as name1,department.ID as id2,department.Name
as name2 from Employee as employee right join Department as department on employee.DepNo=
department.ID

select elements(employee.Name) from Employee as employee
(不明白elements到底是做什么用的?望給于說明)
等等
5。數學函數
JDO目前似乎還不支持此類特性。
avg(...), sum(...), min(...), max(...)

count(*)

count(...), count(distinct ...), count(all...)

其用法和SQL基本相同

select distinct employee.name from Employee as employee
select count(distinct employee.name),count(employee) from Employee as employee

6。polymorphism (暫時不知道如何解釋?)
from com.test.Animal as animal
不光得到所有Animal得實例,而且可以得到所有Animal的子類(假如我們定義了一個子類Cat)
一個比較極端的例子
from java.lang.Object as o
可以得到所有持久類的實例

7。where語句
定義查詢語句的條件,舉幾個例子吧:
from Employee as employee where employee.Name='Jplateau'
from Employee as employee where employee.Name like 'J%'
from Employee as employee where employee.Name like '%u'
在where語句中“=”不光可以比較對象的屬性,也可以比較對象,如:
select animal from com.test.Animal as animal where animal.name=dog

8。表達式

在SQL語句中大部分的表達式在HQL中都可以使用:
mathematical Operators +, -, *, /

binary comparison operators =, >=, <=, <>, !=, like

logical operations and, or, not

string concatenation

SQL scalar functions like upper() and lower()

Parentheses ( ) indicate grouping

in, between, is null

JDBC IN parameters ?

named parameters :name, :start_date, :x1 (這種應該是另一種"?"的變通解決方法)

SQL literals 'foo', 69, '1970-01-01 10:00:01.0'

Java public static final constants eg.Color.TABBY

其他不必解釋了,在這里我只想對查詢中的參數問題說明一下:
大家知道在SQL中進行傳遞參數進行查詢的時候,我們通常用PReparedStatement,在語句中寫一大堆的“?”,
在hql中也可以用這種方法,如:
List mates = sess.find(
"select employee.name from Employee as employee " +
"where employee.Name=? ",
name,
Hibernate.STRING
);
(說明:上面利用session里的find方法,在hibernate的api Session中重載了很多find方法,它可以滿足你多種形式的查詢)
上邊是一個參數的情形,這種情況下緊接著引入參數和定義參數的類型,當為多個參數,調用另一個find方法,它的后兩個
參數都是數組的形式。

還有另外一種方法來解決上邊的問題,JDO也有這樣的方法,不過和hibernate的表現形式上有差別,但他們兩個骨子里卻是
一樣的,如:
Query q = sess.createQuery("select employee.name from Employee as employee where employee.Name=:name");
q.setString("name", "Jplateau");
//當有多個參數的時候在此逐一定義
Iterator employees = q.iterate();

9。order 語句
和sql語句沒什么差別,如:
select employee.name from Employee as employee where employee.Name like 'J%' order by employee.ID desc (或者asc)

10。group by 語句
同樣和sql語句沒什么差別,如:

select employee.name,employee.DepNo from Employee as employee group by employee.DepNo

select foo.id, avg( elements(foo.names) ), max( indices(foo.names) ) from eg.Foo foo group by foo.id
{Note: You may use the elements and indices constrUCts inside a select clause, even on databases with no subselects.}
誰幫我解釋一下上邊兩句,謝過!

11。子查詢
hibernate同樣支持子查詢,寫幾個例子:

from eg.Cat as fatcat where fatcat.weight > ( select avg(cat.weight) from eg.DomesticCat cat )

小節:
其實HQL和SQL是非常相似的,在寫的時候你只要時刻想到對象的概念,那么你完全可以用SQL的思想來寫HQL.

參考資源:Hibernate參考手冊第七章以及第九章,建議由時間的并且要用hibernate開發項目的朋友仔細研讀該手冊。

昨天看了《海底總動員》 ,不知道中國的動畫片何時能“站”起來?

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区二区久久精品| 国产精品视频永久免费播放| 久久乐国产精品| 日韩在线观看免费av| 亚洲国产91精品在线观看| 亚洲第一页中文字幕| 久久中文字幕在线视频| 国产欧美日韩精品在线观看| 国产亚洲日本欧美韩国| www.久久久久久.com| 北条麻妃一区二区三区中文字幕| 国产精品一区专区欧美日韩| 亚洲午夜未删减在线观看| 日韩成人激情影院| 亚洲四色影视在线观看| 日韩免费观看视频| 尤物九九久久国产精品的特点| 欧美激情免费看| 亚洲国产成人av在线| 国产欧亚日韩视频| 成人在线精品视频| 亚洲第一视频网站| 日韩电视剧在线观看免费网站| 国产成人综合久久| 国产专区精品视频| 亚洲欧美制服第一页| 欧美日韩xxxxx| 91欧美精品成人综合在线观看| 茄子视频成人在线| 亚洲国产天堂久久综合| 日韩精品中文字幕有码专区| 欧美精品午夜视频| 日韩av中文字幕在线免费观看| 国产美女直播视频一区| 青青草99啪国产免费| 国产国语刺激对白av不卡| 欧美专区国产专区| 久久精品91久久久久久再现| 久久五月天色综合| 久久精品美女视频网站| 91麻豆国产精品| 欧美午夜片欧美片在线观看| 欧美成人性生活| 日韩精品免费在线视频| 国产精品白嫩美女在线观看| 亚洲欧美中文字幕在线一区| 国产一区二区久久精品| 国产日韩亚洲欧美| 日韩的一区二区| 久久久亚洲网站| 国产午夜精品视频免费不卡69堂| 国产日韩欧美视频在线| 日韩大陆欧美高清视频区| 欧美日韩激情网| 欧美电影第一页| 国产极品jizzhd欧美| 国产999精品视频| 国内精品小视频| 成人做爰www免费看视频网站| 九九热这里只有精品6| 色综合视频网站| 精品一区精品二区| 亚洲国产私拍精品国模在线观看| 久久久亚洲成人| 日韩av电影在线网| 韩国欧美亚洲国产| 国产精品亚发布| 国产午夜精品全部视频在线播放| 亚洲999一在线观看www| 亚洲色图日韩av| 国外成人免费在线播放| 在线观看日韩专区| 色综合导航网站| 国内精品久久久久| 久久影院中文字幕| 午夜免费在线观看精品视频| 伊人青青综合网站| 久久精品亚洲一区| 视频直播国产精品| 欧美成人手机在线| 久久久欧美精品| 欧美成人h版在线观看| 国语自产偷拍精品视频偷| 亚洲精品v天堂中文字幕| 亚洲欧美日韩一区二区三区在线| 日韩二区三区在线| 美日韩丰满少妇在线观看| 伊人久久久久久久久久久| 久久久亚洲精选| 日韩精品在线视频美女| 欧美成aaa人片免费看| 日本国产高清不卡| 亚洲国产精品va在线看黑人动漫| 777午夜精品福利在线观看| 亚洲精品国产品国语在线| 中文字幕亚洲专区| 亚洲精品中文字幕有码专区| 69av视频在线播放| 亚洲精品电影在线| 国产精品久久久久久久久久三级| 亚洲欧美国产精品专区久久| 91久久综合亚洲鲁鲁五月天| 亚洲天堂av网| 欧美特黄级在线| 国产精品女人久久久久久| 日本成人在线视频网址| 亚洲人成电影在线播放| 国产精品第七十二页| 久久精品久久久久| 日韩中文字幕在线观看| 亚洲性69xxxbbb| 久久久久国色av免费观看性色| 国产精品69精品一区二区三区| 亚洲国产三级网| 日韩精品在线视频美女| 久久青草精品视频免费观看| 欧美黑人狂野猛交老妇| 日韩av中文在线| 国产亚洲精品综合一区91| 日韩国产激情在线| 亚洲欧洲免费视频| 国产99久久精品一区二区| 亚洲天堂免费观看| 国产在线精品一区免费香蕉| 中文字幕亚洲二区| 久久久久久久av| 中文字幕精品www乱入免费视频| 成人羞羞国产免费| 国产精品成人一区二区| 亚洲最大激情中文字幕| 另类天堂视频在线观看| 亚洲xxxx妇黄裸体| 亚洲精品网站在线播放gif| 国产伦精品一区二区三区精品视频| 国产精品免费一区二区三区都可以| 视频一区视频二区国产精品| 伊人伊成久久人综合网小说| 26uuu另类亚洲欧美日本老年| 91人成网站www| 国产精品一区二区久久| 日韩电影免费在线观看中文字幕| 国产精品精品久久久久久| 日韩中文综合网| 不卡在线观看电视剧完整版| 色噜噜狠狠色综合网图区| 91手机视频在线观看| 亚洲精品福利视频| 亚洲91精品在线| 欧美另类精品xxxx孕妇| 日韩中文字幕精品视频| 色一情一乱一区二区| 色悠久久久久综合先锋影音下载| 久久亚洲精品中文字幕冲田杏梨| 国产欧美在线播放| www欧美xxxx| 中文字幕av一区二区三区谷原希美| 韩日欧美一区二区| 国产精品自拍小视频| 91免费国产网站| 国产日韩欧美日韩| 欧洲精品毛片网站| 成人情趣片在线观看免费| 97涩涩爰在线观看亚洲| 国产精品成人久久久久|