亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

HQL基礎(chǔ)

系統(tǒng) 2374 0
1 .from

1.1單表查詢

from eg.cat as cat.其中,cat只是一個(gè)別名,為了用其他子語句的時(shí)候書寫簡(jiǎn)單

1.2多表查詢

from eg.Cat,eg.Dog
from eg.Cat as cat,eg.Dog as dog
2 join相關(guān)
(inner) join
left (outer) join
right (outer) join
full join
HQL同樣對(duì)SQL中的這些特性支持
下面插播一個(gè)小話題,關(guān)于上邊的那些特性,我一直都沒怎么用,今天既然說到這里,就想
把上邊的幾個(gè)特性的用法說一下,也算對(duì)自己的一個(gè)補(bǔ)充:
假設(shè)有兩個(gè)表:部門、員工,下面列舉一些數(shù)據(jù):
員工(Employee):
ID Name DepNo
001 Jplateau 01
002 Jony 01
003 Camel 02
部門(Department):
ID Name
01 研發(fā)部
02 營銷部

在Hibernate中我們操縱的都是對(duì)象,所以我們操縱的是部門類和員工類
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)
那么執(zhí)行結(jié)果是什么呢?
id1 name1 id2 name2
++++++++++++++++++++++++++++++++++++++
001 Jplateau 01 研發(fā)部
002 Jony 01 研發(fā)部

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
那么執(zhí)行結(jié)果又該是什么呢?
id1 name1 id2 name2
++++++++++++++++++++++++++++++++++++++
001 Jplateau 01 研發(fā)部
002 Jony 01 研發(fā)部
003 Camel null null
{就是說此時(shí)我要已第一個(gè)表的記錄多少為準(zhǔn),第二個(gè)表中沒有相應(yīng)紀(jì)錄的時(shí)候填充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
那么執(zhí)行結(jié)果又該是什么呢?
id1 name1 id2 name2
++++++++++++++++++++++++++++++++++++++
001 Jplateau 01 研發(fā)部
002 Jony 01 研發(fā)部
null null 02 營銷部
{就是說此時(shí)我要已第二個(gè)表的記錄多少為準(zhǔn),第一個(gè)表中沒有相應(yīng)紀(jì)錄的時(shí)候填充null}

3 大小寫敏感

4。select語句
就是要確定你要從查詢中返回哪些對(duì)象或者哪些對(duì)象的屬性。寫幾個(gè)例子吧:
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。數(shù)學(xué)函數(shù)
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 (暫時(shí)不知道如何解釋?)
from com.test.Animal as animal
不光得到所有Animal得實(shí)例,而且可以得到所有Animal的子類(如果我們定義了一個(gè)子類Cat)
一個(gè)比較極端的例子
from java.lang.Object as o
可以得到所有持久類的實(shí)例

7。where語句
定義查詢語句的條件,舉幾個(gè)例子吧:
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語句中“=”不光可以比較對(duì)象的屬性,也可以比較對(duì)象,如:
select animal from com.test.Animal as animal where animal.name=dog

8。表達(dá)式

在SQL語句中大部分的表達(dá)式在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, 1 (這種應(yīng)該是另一種"?"的變通解決方法)

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

Java public static final constants eg.Color.TABBY

其他不必解釋了,在這里我只想對(duì)查詢中的參數(shù)問題說明一下:
大家知道在SQL中進(jìn)行傳遞參數(shù)進(jìn)行查詢的時(shí)候,我們通常用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方法,它可以滿足你多種形式的查詢)
上邊是一個(gè)參數(shù)的情形,這種情況下緊接著引入?yún)?shù)和定義參數(shù)的類型,當(dāng)為多個(gè)參數(shù),調(diào)用另一個(gè)find方法,它的后兩個(gè)
參數(shù)都是數(shù)組的形式。

還有另外一種方法來解決上邊的問題,JDO也有這樣的方法,不過和hibernate的表現(xiàn)形式上有差別,但他們兩個(gè)骨子里卻是
一樣的,如:
Query q = sess.createQuery("select employee.name from Employee as employee where employee.Name=:name");
q.setString("name", "Jplateau");
//當(dāng)有多個(gè)參數(shù)的時(shí)候在此逐一定義
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同樣支持子查詢,寫幾個(gè)例子:

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

HQL基礎(chǔ)


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦?。。?/p>

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 9久久免费国产精品特黄 | 99热这里只有精 | 四虎院影永久在线观看 | 日本精品a在线 | 久久艹在线 | 久久国产精品一区二区 | 国产精品在线 | 日日操视频 | 日本一级看片免费播放 | 浮力影院欧美三级日本三级 | 成人最新午夜免费视频 | 亚洲日本久久久午夜精品 | 色综合亚洲综合网站综合色 | 国产网红精品 | 国产成人精品日本亚洲麻豆 | 国产伦精品一区三区视频 | 日日日日日日bbbbb视频 | 国产精品精品 | 色天天色综合 | 日本一区二区三区久久 | 91精品久久久久亚洲国产 | 久久精品国产99久久无毒不卡 | 免费性网站| 中文国产成人精品久久水 | 热久久久久 | 亚洲精品久久久久久久久久ty | 真实的国产乱xxxx在线播放 | www.黄色片网站 | 国产成人综合一区精品 | 欧美日韩视频一区二区 | 全部无卡免费的毛片在线看 | 丁香激情综合色伊人久久 | 99国产精品一区二区 | 国产九九 | 97在线视频免费公开观看 | 国产一二三区在线 | 国产精品伦理一二三区伦理 | 日本精品夜色视频一区二区 | 亚洲国产香蕉视频欧美 | 久久精品www| 亚洲狠狠婷婷综合久久久久网站 |