<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    一路拾遺
    Collect By Finding All The Way ......
    posts - 81,comments - 41,trackbacks - 0

    一、基礎(chǔ)入門

    從一個最基本的對象關(guān)系映像自動化程序,了解Hibernate組成的基本元素,并進一步了解Hibernate的基礎(chǔ)語義、配置等概念。

    1.O/R映像入門第一個Hibernate程序很簡單,將一個對象映像至一個數(shù)據(jù)表

    1.1配置Hibernate
    Hibernate是ORM的解決方案,其底層對數(shù)據(jù)庫的操作依賴于JDBC,所以您必須先取得JDBC驅(qū)動程序,在這邊所使用的是MySQL,所以您必須至MySQL®Connector/J取得MySQL的JDBC驅(qū)動程序。

    接下來至Hibernate官方網(wǎng)站取得hibernate 3.0。

    解開zip檔案后,當中的hibernate3.jar是必要的,而在lib目錄中還包括了許多jar檔案,您可以在Hibernate 3.0官方的參考手冊上找到這些jar的相關(guān)說明,其中必要的是antlr、dom4j、CGLIB、asm、Commons Collections、Commons Logging、 EHCache,Hibernate底層還需要Java Transaction API,所以您還需要jta.jar,到這邊為止,總共需要以下的jar檔案:

    Hibernate可以運行于單機之上,也可以運行于Web應(yīng)用程序之中,如果是運行于單機,則將所有用到的jar檔案(包括JDBC驅(qū)動程序)設(shè)定至CLASSPATH中,如果是運行于Web應(yīng)用程序中,則將jar檔案置放于WEB-INF/lib中。

    如果您還需要額外的Library,再依需求加入,例如JUnit、Proxool等等,接下來可以將etc目錄下的 log4j.properties復(fù)制至Hibernate項目的Classpath下,并修改一下當中的 log4j.logger.org.hibernate為error,也就是只在錯誤發(fā)生時顯示必要的訊息。

    接著設(shè)置基本的Hibernate配置文件,可以使用XML或Properties檔案,這邊先使用XML,檔名預(yù)設(shè)為hibernate.cfg.xml:

    hibernate.cfg.xml

                

    <?xml version="1.0" encoding="utf-8"?>
    <!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    " <hibernate-configuration>
    <session-factory>
    <!-- 顯示實際操作數(shù)據(jù)庫時的SQL -->
    <property name="show_sql">true</property>
    <!-- SQL 方言,這邊設(shè)定的是MySQL -->
    <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
    <!-- JDBC 驅(qū)動程序 -->
    <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
    <!-- JDBC URL -->
    <property name="connection.url">jdbc:mysql://localhost/demo</property>
    <!-- 數(shù)據(jù)庫使用者 -->
    <property name="connection.username">caterpillar</property>
    <!-- 數(shù)據(jù)庫密碼 -->
    <property name="connection.password">123456</property>
    <!-- 以下設(shè)置對象與數(shù)據(jù)庫表格映像文件 -->
    </session-factory>
    </hibernate-configuration>

    配置文件中已經(jīng)加上批注為每一個項目作了說明,其中對象與數(shù)據(jù)庫表格映像文件還有待加入。

    1.2第一個Hibernate
    這邊以一個簡單的單機程序來示范Hibernate的配置與功能,首先作數(shù)據(jù)庫的準備工作,在MySQL中新增一個demo數(shù)據(jù)庫,并建立user表格:

    CreateUser2MySQL.sql

                

    CREATE TABLE user (
    id INT(11) NOT NULL auto_increment PRIMARY KEY,
    name VARCHAR(100) NOT NULL default '',
    age INT
    );

    對于這個表格,您有一個User類別與之對應(yīng),表格中的每一個字段將對應(yīng)至User實例上的Field成員。

    User.java

                

    package onlyfun.caterpillar;
    public class User {
    private Integer id;
    private String name;
    private Integer age;
    // 必須要有一個預(yù)設(shè)的建構(gòu)方法
    // 以使得Hibernate 可以使用Constructor.newInstance()建立對象
    public User() {
    }
    public Integer getId() {
    return id;
    }
    public void setId(Integer id) {
    this.id = id;
    }
    public String getName() {
    return name;
    }
    public void setName(String name) {
    this.name = name;
    }
    public Integer getAge() {
    return age;
    }
    public void setAge(Integer age) {
    this.age = age;
    }
    }

    其中id是個特殊的屬性,Hibernate會使用它來作為主鍵識別,您可以定義主鍵產(chǎn)生的方式,這是在XML映像文件中完成,為了告訴Hibernate您所定義的User實例如何映像至數(shù)據(jù)庫表格,您撰寫一個XML映射文件檔名是User.hbm.xml,如下所示:

    User.hbm.xml

                

    <?xml version="1.0" encoding="utf-8"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    " <hibernate-mapping>
    <class name="onlyfun.caterpillar.User" table="user">
    <id name="id" column="id" type="java.lang.Integer">
    <generator class="native" />
    </id>
    <property name="name" column="name" type="java.lang.String" />
    <property name="age" column="age" type="java.lang.Integer" />
    </class>
    </hibernate-mapping>

    <class>卷標的name屬性為所映像的對象,而table為所映像的表格;<id>中column屬性指定了表格字 段,而type屬性指定了User實例的中的id之型態(tài),這邊type中所設(shè)定的是直接指定Java中的對象型態(tài),Hibernate也定義有自己的映像 型態(tài),作為Java對象與SQL型態(tài)的標準對應(yīng)型態(tài)(因為語言所提供的類型并不一定與數(shù)據(jù)庫的類型對應(yīng)),這之后會再說明。

    <id>中主鍵的產(chǎn)生方式在這邊設(shè)定為"native",表示主鍵的生成方式由Hibernate根據(jù)數(shù)據(jù)庫Dialect的定義來決定,之后還會介紹其它主鍵的生成方式。

    同樣的,<property>標簽中的column與type都各自指明了表格中字段與對象中屬性的對應(yīng)。

    接著必須在Hibernate配置文件hibernate.cfg.xml中指明映像文件的位置,如下加入映像文件位置:

    hibernate.cfg.xml

                

    <?xml version="1.0" encoding="utf-8"?>
    <!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    " <hibernate-configuration>
    <session-factor>
    ....
    <!-- 對象與數(shù)據(jù)庫表格映像文件 -->
    <mapping resource="onlyfun/caterpillar/User.hbm.xml"/>
    </session-factory>
    </hibernate-configuration>

    接下來撰寫一個測試的程序,這個程序直接以Java 程序設(shè)計人員熟悉的語法方式來操作對象,而實際上也直接完成對數(shù)據(jù)庫的操作,程序?qū)⒁还P數(shù)據(jù)存入表格之中:

    FirstHibernate.java

                

    package onlyfun.caterpillar;
    import org.hibernate.Session;
    import org.hibernate.SessionFactory;
    import org.hibernate.Transaction;
    import org.hibernate.cfg.Configuration;
    public class FirstHibernate {
    public static void main(String[] args) {
    // Configuration 負責(zé)管理 Hibernate 配置訊息
    Configuration config = new Configuration().configure();
    // 根據(jù) config 建立 SessionFactory
    // SessionFactory 將用于建立 Session
    SessionFactory sessionFactory = config.buildSessionFactory();
    //將持久化的物件
    User user = new User();
    user.setName("caterpillar");
    user.setAge(new Integer(30));
    //開啟Session,相當于開啟JDBC 的Connection
    Session session = sessionFactory.openSession();
    //Transaction 表示一組對DB 的交易
    Transaction tx = session.beginTransaction();
    //將對象映像至數(shù)據(jù)庫表格中儲存
    session.save(user);
    tx.commit();
    session.close();
    sessionFactory.close();
    System.out.println("新增資料OK!請先用MySQL 觀看結(jié)果!");
    }
    }

    如您所看到的,程序中只需要直接操作User 對象,并進行Session 與Transaction 的相關(guān)操作,Hibernate 就會自動完成對數(shù)據(jù)庫的操作,您看不到任何一行JDBC 或SQL 的陳述,撰寫好以上的各個檔案之后,各檔案的放置位置如下:

    接著可以開始運行程序,結(jié)果如下:

    FirstHibernate執(zhí)行結(jié)果

                

    Hibernate: insert into user (name, age) values (?, ?)

    新增資料OK!請先用MySQL 觀看結(jié)果!

    執(zhí)行結(jié)果中顯示了Hibernate 所實際使用的SQL,由于這個程序還沒有查詢功能,所以要
    進入MySQL 中看看新增的數(shù)據(jù),如下:

    MySQL 中查詢結(jié)果

                

    mysql> select * from user;
    +----+-------------+------+
    | id | name | age |
    +----+-------------+------+
    | 1 | caterpillar | 30 |
    +----+-------------+------+
    1 row in set (0.03 sec)

    Comments

    第四段代碼的標題應(yīng)該是hibernate.cfg.xml

    1.3 第二個 Hibernate
    在 第一個 Hibernate 中介紹如何使用Hibernate 在不使用SQL 的情況下,以Java 中操作對象的習(xí)慣來插入數(shù)據(jù)至數(shù)據(jù)庫中,當然儲存數(shù)據(jù)之后,更重要的是如何將資料讀出,Hibernate 中也可以讓您不寫一句SQL,而以Java 中操作對象的習(xí)慣來查詢數(shù)據(jù)。

    直接來看個范例:

    SecondHibernate.java

                

    package onlyfun.caterpillar;
    import org.hibernate.Criteria;
    import org.hibernate.Session;
    import org.hibernate.SessionFactory;
    import org.hibernate.cfg.Configuration;
    import org.hibernate.criterion.Expression;
    import java.util.Iterator;
    import java.util.List;
    public class SecondHibernate {
    public static void main(String[] args) {
    Configuration config = new Configuration().configure();
    SessionFactory sessionFactory = config.buildSessionFactory();
    Session session = sessionFactory.openSession();
    Criteria criteria = session.createCriteria(User.class);
    // 查詢user 所有字段
    List users = criteria.list();
    Iterator iterator = users.iterator();
    System.out.println("id "t name/age");
    while (iterator.hasNext()) {
    User user = (User) iterator.next();
    System.out.println(user.getId() + " "t " + user.getName() + "/" +
    user.getAge());
    }
    // 查詢user 中符合條件的字段
    criteria.add(Expression.eq("name", "caterpillar"));
    users = criteria.list();
    iterator = users.iterator();
    System.out.println("id "t name/age");
    while (iterator.hasNext()) {
    User user = (User) iterator.next();
    System.out.println(user.getId() + " "t " + user.getName() + "/" +
    user.getAge());
    }
    session.close();
    sessionFactory.close();
    }
    }

    Criteria 對SQL 進行封裝,對于不甚了解SQL 的開發(fā)人員來說,使用Criteria 也可以輕易的進行各種數(shù)據(jù)的檢索,您也可以使用 Expression 設(shè)定查詢條件,并將之加入Criteria中對查詢結(jié)果作限制,Expression.eq()表示設(shè)定符合條件的查詢,例如Expression.eq ("name", "caterpillar")表示設(shè)定查詢條件為"name"字段中為"caterpillar"的數(shù)據(jù)。

    先來看一下執(zhí)行結(jié)果:
    SecondHibernate 執(zhí)行結(jié)果

                

    Hibernate: select this_.id as id0_, this_.name as name0_0_,

    this_.age as age0_0_ from user

    this_id
    id name/age
    1 caterpillar/30
    3 bush/5
    2 momor/26
    Hibernate: select this_.id as id0_, this_.name as name0_0_,

    this_.age as age0_0_ from user

    this_
    where this_.name=?
    id name/age
    1 caterpillar/30

    Criteria 是對象導(dǎo)向式的查詢方式,讓不了解SQL 的開發(fā)人員也可以輕易進行各項查詢,但Criteria 的API 目前還不是很完善,而Hibernate 鼓勵的查詢方式,是透過HQL(Hibernate Query Language)來進行,直接來看個實例:

    SecondHibernateUsingHQ.java

                

    package onlyfun.caterpillar;
    import org.hibernate.Query;
    import org.hibernate.Session;
    import org.hibernate.SessionFactory;
    import org.hibernate.cfg.Configuration;
    import java.util.Iterator;
    import java.util.List;
    public class SecondHibernateUsingHQ {
    public static void main(String[] args) {
    Configuration config = new Configuration().configure();
    SessionFactory sessionFactory = config.buildSessionFactory();
    Session session = sessionFactory.openSession();
    // 使用HQL 建立查詢
    Query query = session.createQuery("from User");
    List users = query.list();
    Iterator iterator = users.iterator();
    System.out.println("id "t name/age");
    while (iterator.hasNext()) {
    User user = (User) iterator.next();
    System.out.println(user.getId() + " "t " + user.getName() + "/" +
    user.getAge());
    }
    System.out.println();
    // 使用HQL 建立查詢
    query = session.createQuery("from User user where user.name like ?");
    // 設(shè)定查詢參數(shù)
    query.setParameter(0, "caterpillar");
    users = query.list();
    iterator = users.iterator();
    System.out.println("id "t name/age");
    while (iterator.hasNext()) {
    User user = (User) iterator.next();
    System.out.println(user.getId() + " "t " + user.getName() + "/" +
    user.getAge());
    }
    session.close();
    sessionFactory.close();
    }
    }

    執(zhí)行結(jié)果:

    SecondHibernateUsingHQ 執(zhí)行結(jié)果

                

    Hibernate: select this_.id as id0_, this_.name as name0_0_,

    this_.age as age0_0_ from user

    this_id
    id name/age
    1 caterpillar/30
    3 bush/5
    2 momor/26
    Hibernate: select this_.id as id0_, this_.name as name0_0_,

    this_.age as age0_0_ from user

    this_
    where this_.name=?
    id name/age
    1 caterpillar/30

    透過Query 接口,您可以先設(shè)定查詢參數(shù),之后透過setXXX()等方法,將指定的參數(shù)值填入,而不用每次都撰寫完整的HQL,Query 的setParameter()方法第一個參數(shù)是指定?出現(xiàn)的位置,從 0 開始,第二個參數(shù)則是設(shè)定查詢條件。

    二、簡單的Hibernate 程序

    這邊以一個簡單的單機程序來示范Hibernate的配置與功能,在這個例子中的一些操作,實際上會使用一些自動化工具來完成,而不一定親自手動操 作設(shè)定,這邊完全手動的原因,在于讓您可以知道Hibernate實際上會作那些動作,在進行范例之前,請先確定前一個主題中的相關(guān)jar檔案都已經(jīng)設(shè)定 在CLASSPATH中。

    我們先作數(shù)據(jù)庫的準備工作,在MySQL中新增一個HibernateTest數(shù)據(jù)庫,并建立USER表格:

                

    CREATE TABLE USER (
    user_id CHAR(32) NOT NULL PRIMARY KEY,
    name VARCHAR(16) NOT NULL,
    sex CHAR(1),
    age INT
    );

    我們先撰寫一個純Java對象,它純綷表示一個數(shù)據(jù)集合,待會我們會將之映像至數(shù)據(jù)庫的表格上,程序如下:

    User.java

                

    package onlyfun.caterpillar;
    public class User {
    private String id;
    private String name;
    private char sex;
    private int age;
    public int getAge() {
    return age;
    }
    public String getId() {
    return id;
    }
    public String getName() {
    return name;
    }
    public char getSex() {
    return sex;
    }
    public void setAge(int i) {
    age = i;
    }
    public void setId(String string) {
    id = string;
    }
    public void setName(String string) {
    name = string;
    }
    public void setSex(char c) {
    sex = c;
    }
    }

    其中id是個特殊的屬性,Hibernate會使用它來作為主鍵識別,我們可以定義主鍵產(chǎn)生的方式,這是在XML映像文件中完成,為了告訴Hibernate對象如何映像至數(shù)據(jù)庫表格,我們撰寫一個XML映射文件檔名是User.hbm.xml,如下所示:

    User.hbm.xml

                

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping
    PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"
    " <hibernate-mapping>
    <class name="onlyfun.caterpillar.User" table="USER">
    <id name="id" type="string" unsaved-value="null">
    <column name="user_id" sql-type="char(32)" />
    <generator class="uuid.hex"/>
    </id>
    <property name="name" type="string" not-null="true">
    <column name="name" length="16" not-null="true"/>
    </property>
    <property name="sex" type="char"/>
    <property name="age" type="int"/>
    </class>
    </hibernate-mapping>

    這個XML文件定義了對象屬性映像至數(shù)據(jù)庫表格的關(guān)系,您可以很簡單的了解對映的方法,像是User對象對應(yīng)至USER表格,其中我們使用 uuid.hex來定義主鍵的產(chǎn)生算法,UUID算法使用IP地址、JVM的啟動時間、系統(tǒng)時間和一個計數(shù)值來產(chǎn)生主鍵。除了使用uuid.hex之外, 我們還可以使用其它的方式來產(chǎn)生主鍵,像是increment等,這可以在Hibernate參考手冊中找到相關(guān)資料。

    <property>卷標用于定義Java對象的屬性,而當中的<column/>卷標用于定義與數(shù)據(jù)庫的對應(yīng),如果您是 手工建立Java對象與數(shù)據(jù)庫表格,則在最簡單的情況下,可以只定義<property name="sex"/>這樣的方式,而由Hibernate自動判斷Java對象屬性與數(shù)據(jù)庫表格名稱對應(yīng)關(guān)系,在< property/>與<column/>標簽上的額外設(shè)定(像是not null、sql-type等),則可以用于自動產(chǎn)生Java對象與數(shù)據(jù)庫表格的工具上。

    接下來我們定義Hibernate配置文件,主要是進行SessionFactory配置,Hibernate可以使用XML或?qū)傩晕募磉M行配 置,我 們這邊先介紹如何使用XML配置,這也是Hibernate所建議的配置方式,我們的文件名是hibernate.cfg.xml,如下:

    hibernate.cfg.xml

                

    <?xml version='1.0' encoding='big5'?>
    <!DOCTYPE hibernate-configuration
    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
    " <hibernate-configuration>
    <session-factory>
    <!-- 顯示實際操作數(shù)據(jù)庫時的SQL -->
    <property name="show_sql">true</property>
    <!-- SQL方言,這邊設(shè)定的是MySQL -->
    <property name="dialect">net.sf.hibernate.dialect.MySQLDialect</property>
    <!-- JDBC驅(qū)動程序 -->
    <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
    <!-- JDBC URL -->
    <property name="connection.url">jdbc:mysql://localhost/HibernateTest</property>
    <!-- 數(shù)據(jù)庫使用者 -->
    <property name="connection.username">caterpillar</property>
    <!-- 數(shù)據(jù)庫密碼 -->
    <property name="connection.password">123456</property>
    <!-- 對象與數(shù)據(jù)庫表格映像文件 -->
    <mapping resource="User.hbm.xml"/>
    </session-factory>
    </hibernate-configuration>

    接下來我們撰寫一個測試的程序,這個程序?qū)⒅苯右訨ava程序設(shè)計人員熟悉的語法方式來操作對象,而實際上也直接完成對數(shù)據(jù)庫的操作,程序?qū)⒁还P數(shù)據(jù)存入表格之中:

    HibernateTest.java

                

    import onlyfun.caterpillar.*;
    import net.sf.hibernate.*;
    import net.sf.hibernate.cfg.*;
    public class HibernateTest {
    public static void main(String[] args) throws HibernateException {
    SessionFactory sessionFactory =
    new Configuration().configure().buildSessionFactory();
    User user = new User();
    user.setName("caterpillar");
    user.setSex('M');
    user.setAge(28);
    Session session = sessionFactory.openSession();
    Transaction tx= session.beginTransaction();
    session.save(user);
    tx.commit();
    session.close();
    sessionFactory.close();         
    System.out.println("新增資料OK!請先用MySQL觀看結(jié)果!");
    }
    }

    Configuration代表了Java對象至數(shù)據(jù)庫的映像設(shè)定,這個設(shè)定是從我們上面的XML而來,接下來我們從Configuration取 得SessionFactory對象,并由它來開啟一個Session,它代表對象與表格的一次會話操作,而 Transaction則表示一組會話操作,我們只需要直接操作User對象,并進行Session與Transaction的相關(guān)操作, Hibernate就會自動完成對數(shù)據(jù)庫的操作。這邊對程序先只作簡單的介紹,之后再詳加說明。

    將所有的.java檔案編譯,并將兩個XML檔案放置在與HibernateTest相同的目錄中,也就是檔案位置如下:

                

    /
    |--HibernateTest.class
    |--User.hbm.xml
    |--hibernate.cfg.xml
    /onlyfun
    /caterpillar
    |--User.class

    OK!現(xiàn)在您可以執(zhí)行HibernateTest,程序?qū)霈F(xiàn)以下的訊息:

                

    log4j:WARN No appenders could be found for logger (net.sf.hibernate.cfg.Environment).
    log4j:WARN Please initialize the log4j system properly.
    Hibernate: insert into USER (name, sex, age, user_id) values (?, ?, ?, ?)

    新增資料OK!請先用MySQL觀看結(jié)果!

    這邊只先進行數(shù)據(jù)的存入,要觀看數(shù)據(jù)存入的結(jié)果的話,請進入MySQL觀看,以下是數(shù)據(jù)庫存入的結(jié)果:

    mysql> SELECT * FROM USER;
    +----------------------------------+-------------+------+------+
    | user_id                          | name        | sex  | age  |
    +----------------------------------+-------------+------+------+
    | 297e3dbdfea6023d00fea60241000001 | caterpillar | M    |   28 |
    +----------------------------------+-------------+------+------+
    1 rows in set (0.00 sec)

    posted on 2008-07-23 16:57 胖胖泡泡 閱讀(461) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 精品日韩亚洲AV无码一区二区三区| 亚洲日韩aⅴ在线视频| 无码人妻AV免费一区二区三区| 亚洲综合激情视频| 亚洲精品在线观看视频| 亚洲依依成人亚洲社区| 免费一级全黄少妇性色生活片 | 亚洲爆乳无码一区二区三区| 蜜桃视频在线观看免费网址入口 | 久久精品免费观看| 西西大胆无码视频免费| 老司机亚洲精品影视www| 亚洲天堂电影在线观看| 黄页免费视频播放在线播放| 久久国产色AV免费看| 日韩免费高清视频| 久久精品国产精品亚洲艾草网| 亚洲黄色在线观看| 国产在亚洲线视频观看| 91精品免费观看| 亚洲一区二区三区四区视频| 国产成人1024精品免费| 国产大片线上免费观看| 亚洲熟女综合一区二区三区| 国内精品免费视频自在线| 久久亚洲国产成人精品性色| 国产精品久久久久免费a∨| 亚洲欧美日本韩国| 67194国产精品免费观看| 相泽亚洲一区中文字幕| 人妻无码久久一区二区三区免费| 最近中文字幕mv免费高清视频8| 四虎永久免费地址在线网站| 亚洲成a人片77777老司机| 一本到卡二卡三卡免费高| 免费国产怡红院在线观看| 亚洲粉嫩美白在线| 蜜桃视频在线观看免费网址入口| 久久青青草原亚洲av无码app| 久久久久亚洲AV无码去区首| 69视频在线是免费观看|