Hibernate 查詢語句
HQL:Hibernate Qusery Language它跟SQL非常相像。HQL是物件導向的(OO,用生命的眼光看待每一個物件,他們是如此 鮮活)。
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 )
識別符號生成器 | 是否依賴資料庫 | OID取值範圍 | 其他 |
increment | × | long,int,short | 不推薦叢集環境下使用 |
identity | √ | long,int,short | |
sequence | √ | long,int,short | |
hilo | × | long,int,short | 只能在一個資料庫中保證唯一 |
native | × | long,int,short | 適合跨資料庫平臺開發 |
uuid.hex | × | 不流行 | |
assigned | × | 適用於自然主鍵 |
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/106943/viewspace-926815/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- hibernate的hql查詢語句總結
- 請教Hibernate中分頁查詢語句怎麼寫?
- Hql查詢語句
- mysql查詢語句MySql
- [Mysql 查詢語句]——查詢欄位MySql
- Elasticsearch查詢語句語法Elasticsearch
- mysql查詢語句集MySql
- SQL查詢語句 (Oracle)SQLOracle
- MySQL查詢阻塞語句MySql
- SQL server 查詢語句SQLServer
- oracle查詢語句大全Oracle
- sql查詢語句流程SQL
- SQL mother查詢語句SQL
- Mysql之查詢語句MySql
- mysql查詢語句5:連線查詢MySql
- [Mysql 查詢語句]——分組查詢group byMySql
- [Mysql 查詢語句]——查詢指定記錄MySql
- Laravel 子查詢語句用法Laravel
- 資料庫查詢語句資料庫
- mysql高階查詢語句MySql
- 多表查詢建表語句
- SQL Server阻塞查詢語句SQLServer
- oracle分頁查詢語句Oracle
- MySQL基礎查詢語句MySql
- Oracle常用的查詢語句Oracle
- 效能優化查詢語句優化
- oracle--06查詢語句Oracle
- SQL查詢語句使用 (轉)SQL
- sql 查詢經典語句SQL
- ORACLE 資料庫 查詢語句與DML語句Oracle資料庫
- Hibernate 查詢
- 使用sql語句查詢平均值,使用sql語句查詢資料總條數, not in 篩選語句的使用SQL
- MySQL內連線查詢語句MySql
- postgresql dba常用sql查詢語句SQL
- hisql ORM 查詢語句使用教程SQLORM
- MySQL的簡單查詢語句MySql
- mysql dba常用的查詢語句MySql
- ORACLE結構化查詢語句Oracle