正 文

Eclipse快速上手Hibernate之入门实例


www.7dspace.com  更新日期:2006-1-26 7:12:20  七度空间


  3. 映射文件

  在javamxj.hibernate包下,新建一个名称为“User.hbm.xml”的文件,使用XMLBuddy编辑它(参考:利用XMLBuddy在Eclipse中开发XML),这样比较方便。文件内容如下:

<?xml version="1.0" encoding="GBK"?>
<!DOCTYPE hibernate-mapping
    PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"> 
 
<hibernate-mapping> 

    <class name="javamxj.hibernate.User" table="UserTable">
        <id name="id">
            <generator class="assigned" />
        </id>
        <property name="username"  />
        <property name="password" />  
    </class>

</hibernate-mapping>

  这个XML文件定义了对象属性映射到数据库表的关系,这里采用了assigned(程序设置)方式生成主键。当然还可以使用其它的方式来产生主键,后面的文章就采用了其它的方式产生主键。<property>标签用于定义Java对象的属性,这里只定义了最简单的方式,由Hibernate自动判断 Java对象属性与数据库表名称对应关系。在<property/>标签上的额外设定(像是not null、sql-type等),则可以用于自动产生Java对象与数据库表的工具上。

  4. 配置文件

   Hibernate可以使用XML或属性文件来进行配置,配置文件名默认为“hibernate.cfg.xml”(或者hibernate.properties)。

  在src目录下,新建一个hibernate.cfg.xml文件,内容如下:

<?xml version='1.0' encoding='GBK'?>
<!DOCTYPE hibernate-configuration
    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd">

<hibernate-configuration> 

    <session-factory> 

        <!-- 是否将运行期生成的SQL输出到日志以供调试 -->
        <property name="show_sql">true</property>
  
        <!-- SQL方言,这里设定的是MySQL -->
        <property name="dialect">net.sf.hibernate.dialect.MySQLDialect</property>
  
        <!-- JDBC驱动程序 -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
  
        <!-- JDBC URL, "?useUnicode=true&characterEncoding=GBK" 表示使用GBK进行编码 -->
        <property name="connection.url">
   jdbc:mysql://localhost:3306/HibernateTest?useUnicode=true&characterEncoding=GBK
        </property>
  
        <!-- 数据库用户名 -->
        <property name="connection.username">root</property> 
   
        <!-- 数据库密码 -->
        <property name="connection.password">javamxj</property> 

        <!-- 指定User的映射文件 -->
        <mapping resource="javamxj/hibernate/User.hbm.xml"/>        

    </session-factory>

</hibernate-configuration>

  注意:这里使用的是“jdbc:mysql://localhost:3306/HibernateTest?useUnicod...”中的HibernateTest数据库,你需要在MySql中建立这个数据库。

  5. 测试程序

  在javamxj.hibernate包下,新建一个Test类,内容如下:

/* 
 * 简单测试一下User类
 * 创建日期 2005-3-31
 * @author javamxj(分享java快乐)
 */
package javamxj.hibernate;

import net.sf.hibernate.*;
import net.sf.hibernate.cfg.*;

public class Test { 

 public static void main(String[] args) { 

  try {
   SessionFactory sf = new Configuration().configure()
     .buildSessionFactory();
   Session session = sf.openSession();
   Transaction tx = session.beginTransaction(); 

   User user = new User();
   user.setUsername("Blog");
   user.setPassword("分享java快乐"); 

   session.save(user);
   tx.commit();
   session.close(); 

  } catch (HibernateException e) {
   e.printStackTrace();
  }
 }
}

  这里简单说说一下流程,首先初始化Configuration,加载Hibernate的配置信息,然后Configuration取得 SessionFactory对象,并由它来开启一个Session,它代表对象与表格的一次会话操作,而 Transaction则表示一组会话操作,我们只需要直接操作User对象,并进行Session与Transaction的相关操作, Hibernate就会自动完成对数据库的操作。

  6. 配置数据库

  在运行测试程序之前,还必须先设置好数据库。

  在MySQL中建立一个HibernateTest数据库,并建立UserTable表,SQL语句如下:

CREATE TABLE usertable (
ID int(6) NOT NULL auto_increment,
username varchar(24) NOT NULL default '',
password varchar(24) NOT NULL default '',
PRIMARY KEY (ID)
);

  这里,HibernateTest与hibernate.cfg.xml配置文件中的HibernateTest相对应,UserTable与hbm映射文件中的UserTable相对应。

  7. 运行程序

  右击Test.java,点击运行,可以看到控制台输出一系列信息,最后一条输出语句应该是:

Hibernate: insert into UserTable (username, password, id) values (?, ?, ?)

  在下篇文章中会介绍如何利用log4j来控制输出信息。

  同时,在数据库中可以看到,数据已经添加进表里了:



  小结:

  Hibernate原理方面我不想多说,实际上知道也不多,况且这方面的资料很多,比如Hibernate本身自带的中文文档、夏昕编写的《Hibernate开发指南》、良葛格编写的“Hibernate入门”等都是非常不错的,现在关于Hibetnate的书籍也多了起来。

  我所作的工作就是要使新手能尽快上手Hibernate,理论方面我不想过多纠缠,尽量以实例说话。我想,与其凭空说一个技术多好多好,倒不如给我一个可以上手的实例操作一下。好了,不多说废话了。

3页,页码:[1] [2] [3] 

上一篇:轻轻松松制作超复杂Excel表头
下一篇:PHP程序员的优化调试技术和技巧
标题:Eclipse快速上手Hibernate之入门实例 作者:javamxj 来源:blog
收藏此页】【打印】【关闭
站 内 搜 索
 

热 点 导 读
特 别 推 荐