• <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ù)庫進(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ù)庫的記錄有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ù)庫記錄。如果在持久化類中有相同的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爽| 综合久久给合久久狠狠狠97色| 精品久久久久久无码中文字幕 | 一本色道久久88精品综合| 少妇熟女久久综合网色欲| 久久精品国产亚洲av麻豆蜜芽| 欧美一级久久久久久久大| 久久精品国产影库免费看 | 伊人 久久 精品| 亚洲国产成人精品91久久久| 午夜精品久久久久久中宇| 色综合久久综精品| 久久精品中文无码资源站| 香蕉久久夜色精品国产小说| A级毛片无码久久精品免费| 国产精品九九久久免费视频 | 久久久久亚洲精品天堂久久久久久| 久久人人爽人人爽人人片AV高清 | 色偷偷久久一区二区三区| 人妻无码精品久久亚瑟影视| 91久久精一区二区三区大全| 久久免费看黄a级毛片| 久久亚洲天堂| 久久国产精品免费一区| 热99re久久国超精品首页| 久久99国产精一区二区三区| 久久精品国产亚洲AV香蕉| 国产成人综合久久精品红| 香蕉久久永久视频| 久久久久国色AV免费观看| 精品欧美一区二区三区久久久 | 日本精品一区二区久久久| 国产L精品国产亚洲区久久| 日本免费一区二区久久人人澡| 热久久这里只有精品| 国产综合成人久久大片91| 99久久精品免费看国产| 久久精品国产欧美日韩| 欧美久久久久久| 亚洲精品无码成人片久久| 亚洲AV无一区二区三区久久|