問題一: hibernate是什么?
 hibernate一種ORM工具,是連接 java 應(yīng)用程序和關(guān)系數(shù)據(jù)庫的中間件,這是對JDBC的封裝,主要負(fù)責(zé) java 對象的持久化.

問題二:hibernate中所需要的各 jar 分別起什么作用?
 
hibernate3.jar  編譯hibernate所必須的jar 文件

第三方 jar文件(即hibernate自身所使用的其它jar文件,有以下介紹的jar文件,目前階級對于我們開發(fā)一個使用hibernate技術(shù)底層實現(xiàn)的項目已經(jīng)夠用了)

antlr-2.7.6rc1.jar  :
 ANTLR (ANother Tool for Language Recognition)
是一個PCCTS制定的語言工具,它為他創(chuàng)建認(rèn)定者,程序編譯者,翻譯者提供
一個包括 java,c#和C++在內(nèi)的語法描述框架,使用from 多態(tài)查詢語句時需要它。

cglib-2.1.3.jar:
 CGL (Code Generation Libray) 是一種高性能,高質(zhì)量
的代碼產(chǎn)生庫, hibernate 用它來實現(xiàn) po (persistent object)字節(jié)碼的動態(tài)生成

asm.jar和asm-attrs.jar:  ObjectWeb的字節(jié)碼操縱框架,用來動態(tài)生成java代碼。

commons-collections-2.1.1.jar : Apache Commons 包中的一個,包含了一些Apache
開發(fā)的集合類,功能比java.util.*;強(qiáng)大

commons-logging-1.0.4.jar:   Jakarta的通用日志記錄包

dom4j-1.6.1.jar: 是一個JAVA的XML API  類似于jdom,用來讀寫XML文件,dom4j是一個非常
優(yōu)秀的JAVA XML API, 具有性能優(yōu)異,功能強(qiáng)大和易使用的特點,同時它也是一個開放源代碼
的軟件,可以在 SourceForge上找到它。

eheache-1.1.jar:  EHCahe是一個純JAVA的進(jìn)程中的緩存,它具有經(jīng)下特性,快速、簡單、為
hibernate充當(dāng)可插入的緩存,最小的依賴性和全面的文檔和測試。

jta.jar:  java Transaction API (JTA) 規(guī)范的包,是指定事務(wù)和事務(wù)處理和分布式事務(wù)處理系統(tǒng)
之間的標(biāo)準(zhǔn),JAVA接口,包括資源管理,應(yīng)用服務(wù),和事務(wù)應(yīng)用程序。

log4j-1.2.9.jar:  hibernate 使用 Commons Logging  API 可以使用log4j作為實施,log的機(jī)制,如果
把log4j庫放到上下文類目錄中,commons Logging 就會使用log4j 和它上下文類路徑找到的log4j.properties文件

ant.jar:
Ant編譯工具的jar包,用來編譯Hibernate源代碼的。如果你不準(zhǔn)備修改和編譯Hibernate源代碼,那么就沒有什么用,可選的jar

c3p0.jar
C3PO是一個數(shù)據(jù)庫連接池,Hibernate可以配置為使用C3PO連接池。如果你準(zhǔn)備用這個連接池,就需要這個jar包。

jaas.jar:
JAAS是用來進(jìn)行權(quán)限驗證的,已經(jīng)包含在JDK1.4里面了。所以實際上是多余的包。
有了以上基本的jar文件,對于我們現(xiàn)階段利用hibernate開發(fā)一般的項目已經(jīng)足夠了。

問題三:hibernate.cfg.xml詳解?
                <property name="show_sql">true</property>       是否打印hibernate執(zhí)行的SQL語句
        <property name="format_sql">true</property>     打印sql語句時是否執(zhí)行格式化
            <property name="dialect">org.hibernate.dialect.MySQLDialect</property>  配置數(shù)據(jù)庫的方言,主要是根據(jù)底層的數(shù)據(jù)庫不同產(chǎn)生不同的sql語句
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>  配置驅(qū)動程序名
        <property name="connection.url">jdbc:mysql://localhost:3306/xubindb</property> 配置驅(qū)動程序URL
        <property name="connection.username">root</property>        配置用戶名
        <property name="connection.password">1234</property>        配置密碼

        <mapping resource="xubin/ums/entity/Student.hbm.xml"/>   指定映射的實體類的配置文件

問題四:xxxx.hbm.xml詳解?
    
<hibernate-mapping package="xubin.ums.entity">         指定映射實體類的包名

    <class name="Person" table="person">           實體類名映射表名
        <id name="id" column="id">             ID生成策略
            <generator class="native"/>
        </id>
        <property name="name" column="name"/>  實體類中的屬性名映射表中的字段名
        </class>
   
</hibernate-mapping>

問題五:寫hibernate代碼時要注意什么?

   1、首先要確保把hibernate所需用要的jar文件全部加入 classpath中(hibernate3.jar,  hibernate所需要的第三方jar,以及數(shù)據(jù)庫的驅(qū)動等)
   2、配置hibernate.cfg.xml文件,注意程序要訪問底層數(shù)據(jù)庫的類型而采用不同的配置
   3、配置xxxx.hbm.xml文件,把實體類的各部分分別與數(shù)據(jù)庫的表相映射起來
   4、編程hibernate操作的代碼
       
        Configuration config = new Configuration().configure();// 初始化并讀取hibernate.cfg.xml文件
        sessionFactory = config.buildSessionFactory(); //取得一個會話工廠
        Session session = sessionFactory.openSession();//利用會話工廠得到一個會話實體
        Transaction trans = session.beginTransaction();//設(shè)置事務(wù)的開始
        session.save(obj); //持久化對象obj
        trans.commit();   //提交事務(wù)
        session.close();//關(guān)閉會話釋放資源
 

問題六: hibernate中的ID生成策略。

hilo 高低位算法 :  使用時要建成一個單行單列的表,利用列的值根據(jù)算法來生成
increment:  只用于測試用,此操作只能限于一個線程操作
sequence: 針對oracle 數(shù)據(jù)庫來生成的ID規(guī)則
seqhilo: 利用 sequence 當(dāng)作種子來生成
uuid:  利用IP和時間來生成唯一的
identity:  針對 mysql db2 sysbase 等不同的底層數(shù)據(jù)庫方言來生成
native: 跨數(shù)據(jù)庫平臺的生成規(guī)則, 讓自己去判斷數(shù)據(jù)庫來生成(identity ,  sequence , hilo 三種選)
assigned: 自定義的,意思就是自己要在程序中手動的指定值
foreign:借用別的表的主鍵來生成ID
descriminator:  繼承關(guān)系映射時使用,整個層次一張表的建模時使用