日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

hibernate使用小結

 昵稱22369024 2015-05-03
  • hibernate適用情況

    在最近的項目開發(fā)過程中,需要實現(xiàn)數(shù)據(jù)的持久化工作,原本打算在應用程序和數(shù)據(jù)庫中中間增加一層數(shù)據(jù)持久層,使用Hibernate技術實現(xiàn)該功能。經(jīng)過測試發(fā)現(xiàn)hibernate操作數(shù)據(jù)庫的速度較慢,因此放棄的hibernate的使用。

    究竟是什么原因呢?分析hibernate源碼,未發(fā)現(xiàn)hibernate采用多線程異步操作數(shù)據(jù)庫,雖然它也支持緩存管理(hibernate有兩級緩存結構),但在數(shù)據(jù)庫更新頻繁的環(huán)境下,有無緩存差別不大。當然,如果程序要頻繁更新數(shù)據(jù)庫并且對性能要求比較高的話,采用hibernate不是一個十分妥當?shù)慕鉀Q方案。如果對數(shù)據(jù)庫的操作大多數(shù)是查詢的話,采用hibernate應該相當不錯,在開啟hibernate緩存的情況下,應該對性能不會造成太大的影響。

  • hibernate使用中關鍵的類

Configuration

    Configuration 類負責讀取 Hibernate.cfg.xml 文件,管理Hibernate 的配置信息。Hibernate 運行時需要獲取一些底層實現(xiàn)的基本信息,其中幾個關鍵屬性包括:

    數(shù)據(jù)庫URL

    數(shù)據(jù)庫用戶

    數(shù)據(jù)庫用戶密碼

    數(shù)據(jù)庫JDBC驅動類

    數(shù)據(jù)庫dialect,用于對特定數(shù)據(jù)庫提供支持,其中包含了針對特定數(shù)據(jù)庫特性的實現(xiàn),如Hibernate數(shù)據(jù)類型到特定數(shù)據(jù)庫數(shù)據(jù)類型的映射等。

SessionFactory

    SessionFactory負責創(chuàng)建Session實例。可以通過Configuation 實例構建SessionFactory。

Session

    Session是持久層操作的基礎,相當于JDBC中的Connection。Session實例通過SessionFactory實例構建。

Query

   用來執(zhí)行查詢操作。通常由Session類來構建。

Transaction

    每次對數(shù)據(jù)庫的操作都可以看作是一次事務。

    事務通常由session使用session.beginTransaction()方法構建。事務結束要使用commit()方法提交,如果出錯可以使用rollback()方法回滾。

  • 使用步驟

    1.創(chuàng)建數(shù)據(jù)庫

      創(chuàng)建javabean

      創(chuàng)建配置文件Hibernate.cfg.xml和類名.hbm.xml

    2.根據(jù)hibernate配置文件完成初始化,并獲得一個Configuration類的實例。

      Configuration config = new Configuration().configure();

    3.然后根據(jù)該實例構建一個SessionFactory的實例.

      SessionFactory sessionFactory = config.buildSessionFactory();

    4.根據(jù) SessionFactory的實例構建一個Session的實例

      Session session = sessionFactory.openSession();

    5.調用Session所提供的save、find、load 、flush等方法完成持久層操作;

      也可以通過session.createQuery方法創(chuàng)建Query一個實例來執(zhí)行查找操作。

  • 配置Hibernate.cfg.xml一個典型的配置文件(Hibernate.cfg.xml),下面配置文件中的注釋應該已經(jīng)比較清楚:<?xml version="1.0" encoding="UTF-8" ?><hibernate-configuration>    <!-- SessionFactory 配置 -->    <session-factory>    <!-- 數(shù)據(jù)庫URL -->    <property name="hibernate.connection.url">    jdbc:oracle:thin:@10.172.10.39:1521:ora92    </property>    <!-- 數(shù)據(jù)庫JDBC驅動 -->    <property name="hibernate.connection.driver_class">    oracle.jdbc.driver.OracleDriver    </property>    <!-- 數(shù)據(jù)庫用戶名 -->    <property name="hibernate.connection.username">icor</property>    <!-- 數(shù)據(jù)庫用戶密碼 -->    <property name="hibernate.connection.password">icor01</property>    <!--dialect ,每個數(shù)據(jù)庫都有其對應的Dialet以匹配其平臺特性 -->    <property name="dialect">    net.sf.hibernate.dialect.OracleDialect    </property>    <!-- 是否將運行期生成的SQL輸出到日志以供調試 -->    <property name="hibernate.show_sql">True</property>    <!-- 事務管理類型,這里我們使用JDBC Transaction -->    <property name="hibernate.transaction.factory_class">    net.sf.hibernate.transaction.JDBCTransactionFactory    </property>    <!--映射文件配置,使用相對路徑 -->    <mapping resource="conf/UserInfo.hbm.xml" />    <mapping resource="conf/IcorInfo.hbm.xml" />    </session-factory></hibernate-configuration>

    先寫到這,后續(xù)跟新。。。


    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內容均由用戶發(fā)布,不代表本站觀點。請注意甄別內容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多