欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在Java的Hibernate框架中使用SQL語句的簡單介紹

 更新時間:2016年01月03日 15:23:54   作者:cxshun  
這篇文章主要介紹了在Java的Hibernate框架中使用SQL語句的方法,Hibernate是Java的SSH三大web開發(fā)框架之一,需要的朋友可以參考下

Hibernate中有HQL查詢語法。但我們用得比較熟的還是數(shù)SQL語句,那么應(yīng)該怎么來讓Hibernate支持SQL呢?這個不用我們?nèi)タ紤]了,Hibernate團隊已經(jīng)早就做好了。
       廢話不說,直接來例子啦。

select * from t_user usr 

 
  上面是一條SQL語句,又是廢話,是個人都知道。我們想讓Hibernate執(zhí)行這條語句,怎么辦呢?看代碼:

Query query = session.createSQLQuery("select * from t_user usr"); 

  就這樣,剩下來的,大家應(yīng)該都知道了,平常的查詢。
        那查詢完之后,返回的是什么東西呢?

while(iter.hasNext()){ 
 Object[] objs = (Object[])iter.next(); 
 for (int i = 0; i < objs.length; i++) { 
 System.out.print(objs[i]); 
 } 
 System.out.println(); 
} 

  返回的每個結(jié)果都是Object[]數(shù)組,
     
        這時又有人跑出來說面向?qū)ο罄?。對,就是面向?qū)ο?,唉,沒辦法。
        我們繼續(xù)看:

select {usr.*} from t_user usr 

  看到這里,估計某些童鞋開始雞動啦,那個大括號什么東西啦?
    別急,慢慢來。我們先繼續(xù)看代碼。

復(fù)制代碼 代碼如下:

Query query = session.createSQLQuery("select {usr.*} from t_user usr").addEntity(TUser.class);

  我們看到跟前面不同的是,我們加了一個addEntity,是什么意思呢?
    我們直接API,看到這樣一串解釋:
 addEntity
SQLQuery addEntity(String tableAlias,
   Class entityType)
Declare a "root" entity
Parameters:
tableAlias - The SQL table alias
entityType - The java type of the entity to add as a root

       有跟沒一個樣,杯具。只能自己動手用用。
       第一個參數(shù)是指表的別名,就像上面的語句,我們表的別名是usr,所以第一個參數(shù)為usr,而第二個是指查詢到的結(jié)果需要映射到哪個類,這里由于我們在映射文件中是通過TUser映射到t_user表,所以我們這里當(dāng)然也就是TUser啦。然后一查,有SQL語句出來,而且查到的結(jié)果是TUser類型的。
       我們查到的結(jié)果是:

org.hibernate.tutorial.domain6.TUser@198cb3d 

  當(dāng)然,你們的肯定跟我不一樣的。不要雞動。
 
    也許我們并不需要全部進行查出,這時,我們需要的只是設(shè)定別名即可:

select u.id as {usr.id},u.name as {usr.name},u.age as {usr.age} from t_user u 

  我們看到我們用了as指定了字段的別名,程序中還是一樣:

復(fù)制代碼 代碼如下:

Query query = session.createSQLQuery("select u.id as {usr.id},u.name as {usr.name},u.age as {usr.age} from t_user u").addEntity("usr",TUser.class);

  這個簡單,不多說。
 
         以前我們講到,有些團隊會規(guī)定不給在代碼中寫SQL語句,這又需要配置文件出馬啦。
         我們可以在配置文件中添加:
<sql-query name="queryTUser"> 
 <return alias="usr" entity-name="org.hibernate.tutorial.domain6.TUser" /> 
 select {usr.*} from t_user usr where name=:name 
</sql-query> 

  注意,這里的entity-name需要寫完整的包名,不然會報錯的。這里我們有子標(biāo)簽return,它指定了表的別名和類名,這樣我們在運行時就不需要再addEntity了。
    看代碼:

Query query = session.getNamedQuery("queryTUser"); 
query.setParameter("name","shun"); 
List list = query.list(); 
Iterator iter = list.iterator(); 

 
  我們直接這樣就OK了,注意,我們并沒有加addEntity了,主要還是歸功于配置文件中的配置。
    注意,如果在配置文件中配置,一定要有return子標(biāo)簽指定表別名和類名。這個主要是避免了我們讀取語句時的重復(fù)判斷。
  
 
    上面講了這么久,我們一直在講有別名的表,那么如果我們的表沒有別名,但又想返回的結(jié)果封裝在對象內(nèi),我們應(yīng)該怎樣呢?

select * from t_user usr 

  很簡單,只要調(diào)用addEntity的重載方法addEntity(Class clazz)就行了,只需要提供一個類名,而不需要表別名。
 
    當(dāng)然,hibernate也支持存儲過程,只需要在配置文件中把sql-query的callable屬性設(shè)為true即表示當(dāng)前調(diào)用的是存儲過程,由于存儲過程我接觸地不多,以后多研究一下再跟大家一起研究。
  
    我們在調(diào)用session.save等相應(yīng)的對數(shù)據(jù)操作的方法時,它會轉(zhuǎn)換成hibernate內(nèi)置的SQL語句,但如果我們想自己控制SQL語句的格式呢,怎么辦?
    Hibernate實際上也想到了。
    我們直接在映射文件中加入:

<sql-insert> 
 INSERT INTO T_USER (NAME,AGE) values (?,?) 
 </sql-insert> 
 <sql-update> 
 UPDATE USER SET USER_NAME=?,AGE=? WHERE uSER_ID=? 
</sql-update> 

  
  注意,這個需要添加在class標(biāo)簽內(nèi),作為子標(biāo)簽。我們這里全部是大寫字母,是為了跟hibernate默認(rèn)的語句分清,沒有其他意思。
    我們先來看一下insert的調(diào)用:

User user = new User(); 
user.setName("shun123123"); 
user.setAge(23); 

  當(dāng)我們調(diào)用保存時,hibernate的語句是:
Hibernate: 

INSERT INTO USER(USER_NAME,AGE) values(?,?) 

  它調(diào)用了我們配置的sql-insert標(biāo)簽內(nèi)的語句
我們再來看一下update的調(diào)用:

User user = (User)session.get(User.class,new Long(29)); 
user.setName("shun123123"); 
user.setAge(23); 
session.save(user); 

  我們調(diào)用保存,它會自動調(diào)用更新,此時的語句是:
Hibernate: 

UPDATE USER SET USER_NAME=?,AGE=? WHERE uSER_ID=? 

  我們看到輸出的語句是大寫的,也就是調(diào)用了我們配置的語句。
 
    delete語句也是同樣的配置。

相關(guān)文章

  • Java中Map集合的常用方法(非常詳細(xì)!)

    Java中Map集合的常用方法(非常詳細(xì)!)

    Java中的Map是一種鍵值對存儲的數(shù)據(jù)結(jié)構(gòu),它提供了快速查找和訪問數(shù)據(jù)的能力,下面這篇文章主要給大家介紹了關(guān)于Java中Map集合的常用方法,需要的朋友可以參考下
    2024-01-01
  • Java中的CurrentHashMap源碼詳解

    Java中的CurrentHashMap源碼詳解

    這篇文章主要介紹了Java中的CurrentHashMap源碼詳解,HashMap是數(shù)組+鏈表構(gòu)成的,JDK1.8之后,加入了紅黑樹,HashMap默認(rèn)數(shù)組初始化大小為16,如果瞎設(shè)置數(shù)字,它會自動調(diào)整成2的倍數(shù),需要的朋友可以參考下
    2023-12-12
  • SpringBoot解析yml全流程詳解

    SpringBoot解析yml全流程詳解

    本文主要介紹了SpringBoot解析yml全流程詳解,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 詳解Java快速上手用戶后臺管理系統(tǒng)

    詳解Java快速上手用戶后臺管理系統(tǒng)

    只有在實戰(zhàn)中練習(xí)才能真正獲得能力的提升,本篇文章手把手帶你用Java快速上手實現(xiàn)一個用戶后臺管理系統(tǒng),大家可以在過程中查缺補漏,提升水平
    2022-01-01
  • 淺談Spring Boot 2.0遷移指南主要注意點

    淺談Spring Boot 2.0遷移指南主要注意點

    Spring官方的Spring Boot 2變動指南,主要是幫助您將應(yīng)用程序遷移到Spring Boot 2.0,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • java遍歷讀取xml文件內(nèi)容

    java遍歷讀取xml文件內(nèi)容

    這篇文章主要為大家介紹了java遍歷讀取xml文件內(nèi)容,感興趣的小伙伴們可以參考一下
    2016-01-01
  • Java實現(xiàn)撲克牌程序

    Java實現(xiàn)撲克牌程序

    這篇文章主要為大家詳細(xì)介紹了Java實現(xiàn)撲克牌程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 詳解Spring Boot + Mybatis 實現(xiàn)動態(tài)數(shù)據(jù)源

    詳解Spring Boot + Mybatis 實現(xiàn)動態(tài)數(shù)據(jù)源

    這篇文章主要介紹了Spring Boot + Mybatis 實現(xiàn)動態(tài)數(shù)據(jù)源,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Java基于Tcp協(xié)議的socket編程實例

    Java基于Tcp協(xié)議的socket編程實例

    這篇文章主要介紹了Java基于Tcp協(xié)議的socket編程實例,較為詳細(xì)的分析了socket編程客戶端與服務(wù)器端的具體實現(xiàn)步驟與使用技巧,具有一定的參考借鑒價值,需要的朋友可以參考下
    2014-12-12
  • Spring Cloud Alibaba整合Sentinel的實現(xiàn)步驟

    Spring Cloud Alibaba整合Sentinel的實現(xiàn)步驟

    這篇文章主要介紹了Spring Cloud Alibaba整合Sentinel的實現(xiàn)步驟,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10

最新評論