• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            xiaoguozi's Blog
            Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習(xí)慣原本生活的人不容易改變,就算現(xiàn)狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預(yù)料,人們需要更細(xì)心的觀察別人,要隨時(shí)注意才能保護(hù)別人,因?yàn)樗麄兾幢刂雷约阂裁础ぁぁぁぁ?/span>

            用Hibernate肯定會(huì)頻繁的用到session,下面就將Hibernate session中一些經(jīng)常的用方法逐個(gè)的解釋一下。

            Transaction beginTransaction()

            開始一個(gè)工作單元并返回一個(gè)與之相關(guān)Transaction對(duì)象,最為事務(wù)的開始,通常在需要對(duì)數(shù)據(jù)庫(kù)進(jìn)行更改例如save,update或delete時(shí)使用。在事務(wù)結(jié)束后需要調(diào)用Transaction的commit方法提交更改,該方法必須在Hibernate session關(guān)閉之前使用。

            void flush() void clear()

            這兩個(gè)方法通常在一起使用。由于Hibernate有緩存數(shù)據(jù)的功能,所以當(dāng)我們要批量查詢和批量插入時(shí),會(huì)因?yàn)榇罅康木彺娑鴮?dǎo)致內(nèi)存溢出。所以我們可以在執(zhí)行批量插入時(shí)插入一定數(shù)目的數(shù)據(jù)后調(diào)用flush()提交插入,然后調(diào)用clear()清空當(dāng)前Hibernate session內(nèi)的所有緩存。批量查詢同理

            Connection close()

            關(guān)閉Hibernate session,同時(shí)清空所有的緩存。

            Connection connection()

            獲取當(dāng)前Hibernate session使用的JDBC connection。

            boolean contains(Object object)

            返回boolean值,判斷一個(gè)實(shí)例是否與當(dāng)前Hibernate session保持關(guān)聯(lián),即為持久化狀態(tài)。

            Query createQuery(String queryString)

            返回一個(gè)給定HQL語句的Query對(duì)象。

            SQLQuery createSQLQuery(String queryString)

            返回一個(gè)用于執(zhí)行原生SQL語句的SQLQuery對(duì)象

            void delete(Object object)

            刪除與該對(duì)象關(guān)聯(lián)的數(shù)據(jù)里內(nèi)的一條記錄。該對(duì)象可以是處于持久化狀態(tài)也可以是處于瞬態(tài)但與數(shù)據(jù)庫(kù)的記錄有id聯(lián)系。如果該對(duì)象的cascade屬性為delete或all將會(huì)同時(shí)刪除相關(guān)聯(lián)的數(shù)據(jù)。

            void delete(String entityName, Object object)

            不太明白什么意思,占個(gè)位。

            Connection disconnect()

            斷開與session與當(dāng)前JDBC的連接,如果連接有Hibernate管理,則將連接送回連接池,否則將送回給程序本身。

            Object get(Class clazz, Serializable id)

            根據(jù)指定的實(shí)體類以及實(shí)體id返回一個(gè)實(shí)體的實(shí)例。如果找不到記錄則返回null

            Object get(String entityName, Serializable id)

            同上,entity為實(shí)體的名字

            String getEntityName(Object object)

            返回一個(gè)持久化類的實(shí)體名

            Serializable getIdentifier(Object object)

            返回一個(gè)被session緩存的實(shí)體實(shí)例的id

            Query getNamedQuery(String queryName)

            返回一個(gè)在映射文件中定義的命名查詢的query對(duì)象

            SessionFactory getSessionFactory()

            獲取生成當(dāng)前session的SessionFactory

            Transaction getTransaction()

            不說了,地球人都知道

            Object load(Class theClass, Serializable id)

            Object load(String entityName, Serializable id)

            和get方法一個(gè)效果,不同的是該方法在找不到對(duì)應(yīng)記錄時(shí)會(huì)拋出異常

            Serializable save(Object object)

            將一個(gè)實(shí)體實(shí)例持久化,返回該持久化實(shí)例的id。在持久化之前必須手動(dòng)或自動(dòng)的指派id。

            void update(Object object)

            通過給定的分離狀態(tài)的實(shí)例的id更新數(shù)據(jù)庫(kù)記錄。如果在持久化類中有相同的id則會(huì)拋出異常。如果這個(gè)實(shí)例cascade設(shè)置為save-update或all是將同時(shí)更新所有關(guān)聯(lián)的實(shí)例記錄。

            void saveOrUpdate(Object object)

            posted on 2009-07-17 17:16 小果子 閱讀(301) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 學(xué)習(xí)筆記
            亚洲国产精品狼友中文久久久| 久久久亚洲裙底偷窥综合| 成人妇女免费播放久久久| 伊人久久大香线蕉av不变影院| AV色综合久久天堂AV色综合在 | 日批日出水久久亚洲精品tv| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 蜜臀久久99精品久久久久久| 久久综合九色综合网站| 久久线看观看精品香蕉国产| 人妻无码精品久久亚瑟影视 | 伊人久久大香线蕉综合影院首页 | 国产aⅴ激情无码久久| 国产精品一区二区久久精品无码| 久久久这里有精品| 久久综合九色综合97_久久久| 欧美午夜A∨大片久久| 亚洲国产精品热久久| 精品无码久久久久国产| 四虎影视久久久免费观看| 99久久精品免费看国产| 久久久久久亚洲精品成人| 18禁黄久久久AAA片| 久久久久久久综合日本| 欧美久久精品一级c片片| 精品久久久久久无码专区不卡| 久久久精品久久久久影院| 久久天天躁狠狠躁夜夜2020| 久久线看观看精品香蕉国产| 国产精品久久久久天天影视| 久久精品无码午夜福利理论片| 久久精品国产亚洲av麻豆蜜芽 | 四虎国产精品免费久久| 日本加勒比久久精品| 午夜精品久久影院蜜桃| 欧美日韩精品久久久久| 性高朝久久久久久久久久| 四虎国产精品免费久久| 欧美成人免费观看久久| 国产成人综合久久精品红| 久久久久高潮综合影院|