• <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í)筆記
            亚洲国产成人久久笫一页| 天天躁日日躁狠狠久久| 久久国产精品无码网站| 一个色综合久久| 97精品国产97久久久久久免费| 亚洲欧美日韩久久精品| 久久99热狠狠色精品一区| 久久精品国产亚洲av麻豆蜜芽 | 久久精品国产免费一区| 久久受www免费人成_看片中文| 狠狠色丁香久久综合五月| 精品久久久久成人码免费动漫| 欧美亚洲国产精品久久蜜芽| 亚洲第一极品精品无码久久 | 99久久久精品免费观看国产| 狠狠色丁香婷婷久久综合| 国产一区二区三精品久久久无广告| 伊人久久综合无码成人网| 性做久久久久久久久久久| 97精品伊人久久久大香线蕉| 九九久久99综合一区二区| 蜜臀久久99精品久久久久久小说 | 九九99精品久久久久久| 69SEX久久精品国产麻豆| 精品久久久久久久无码 | 伊人久久综合精品无码AV专区 | 久久久久久综合网天天| 国产精品久久久香蕉| 久久亚洲精品成人无码网站| 亚洲欧美久久久久9999| 伊人色综合久久天天人守人婷| 久久久久久久综合综合狠狠| 色欲综合久久躁天天躁| 伊人久久大香线蕉无码麻豆| 久久久亚洲AV波多野结衣| 一本一本久久a久久综合精品蜜桃| 亚洲日本久久久午夜精品| 99精品国产99久久久久久97| 久久精品人人做人人爽97| 热久久国产精品| 国产精品美女久久福利网站|