Hibernate学习笔记(一)O/R 映射入门

HibernateORM的解决方案,其底层对数据库的操作依赖于JDBC,所以您必须先取得JDBC驱动程序,在这边所使用的是MySQL,所以您必须至 MySQL® Connector/J 取得MySQLJDBC驱动程序。

接下来至 Hibernate官方网站 取得hibernate 3.2。

解开zip档案后,当中的hibernate3.jar是必要的,而在lib目录中还包括了许多jar档案,您可以在 Hibernate 3官方参考手册上找到这些jar的相关说明,其中必要的是antlr、dom4j、CGLIB、asm、Commons Collections、Commons Logging、 EHCache(预设快取),Hibernate底层还需要JavaTransaction API,所以您还需要jta.jar,如果您需要连接池,可以使用C3P0连接池,到这边为止,总共需要以下的jar档案: 

  • mysql-connector-java-5.0.5.jar
  • hibernate3.jar
  • antlr.jar
  • asm.jar
  • c3p0.jar
  • cglib.jar
  • commons-logging.jar
  • commons-collections.jar
  • dom4j.jar
  • log4j.jar
  • ehcache.jar
  • jta.jar


Hibernate可以运行於单机之上,也可以运行于Web应用程序之中,如果是运行於单机,则将所有用到的jar档案(包括JDBC驱动程序)设定至CLASSPATH中,如果是运行于Web应用程序中,则将jar档案置放于WEB-INF/lib中。

如果您还需要额外的Library,再依需求加入,例如JUnit、Proxool等等,接下来可以将etc目录下的log4j.properties复 制至Hibernate项目的Classpath下,并修改一下当中的log4j.logger.org.hibernate为error,也就是只在在 错误发生时显示必要的讯息。

接着设置基本的Hibernate配置文件,可以使用XML或Properties档案,这边先使用XML,档名预设为hibernate.cfg.xml,直接置放于Classpath路径之中:

  • hibernate.cfg.xml
<?xml version="1.0" encoding="utf-8"?> 
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
	
<hibernate-configuration> 

    <session-factory> 

    <!-- 显示实际操作数据库时的SQL --> 
    <property name="show_sql">true</property> 
    <!-- 将显示的SQL排版,方便观看 -->
    <property name="format_sql">true</property>
    <!-- SQL方言,这边设定的是MySQL --> 
    <property name="dialect">org.hibernate.dialect.MySQLDialect</property> 
    <!-- JDBC驱动程序 --> 
    <property name="connection.driver_class">com.mysql.jdbc.Driver</property> 
    <!-- JDBC URL --> 
    <property name="connection.url">jdbc:mysql://localhost/demo</property> 
    <!-- 数据库用户 --> 
    <property name="connection.username">caterpillar</property> 
    <!-- 数据库密码 --> 
    <property name="connection.password">123456</property> 

    <!-- 以下设置对象与数据库表格映像文件 --> 

<mappingresource="onlyfun/caterpillar/User.hbm.xml"/>

   </session-factory>

</hibernate-configuration>
  • User.hbm.xml
<?xml version="1.0" encoding="utf-8"?> 
<!DOCTYPE hibernate-mapping 
 PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 
 "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> 

<hibernate-mapping> 

    <class name="onlyfun.caterpillar.User" table="T_USER"> 

        <id name="id" column="id"> 
            <generator class="native"/> 
        </id> 

        <property name="name" column="name"/> 

        <property name="age" column="age"/> 

    </class> 

</hibernate-mapping>
  • User.java
public class User {
    private Long id;
    private String name;
    private Long age;
 
    
    // 以使得Hibernate可以使用Constructor.newInstance()建立物件
    public User() {
    }

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
 
    public Long getAge() {
        return age;
    }

    public void setAge(Long age) {
        this.age = age;
    }
}


  • HibernateUtil.java
package onlyfun.caterpillar;

import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateUtil {
    private static SessionFactory sessionFactory;
    static {
        try {
            sessionFactory = new Configuration().configure()
                    .buildSessionFactory();
        } catch (Throwable ex) {
            throw new ExceptionInInitializerError(ex);
        }
    }

    public static SessionFactory getSessionFactory() {
        return sessionFactory;
    }

    public static void shutdown() {
        getSessionFactory().close();
    }
}
  • HibernateDemo.java(插入)
import org.hibernate.Session;
import org.hibernate.Transaction;

public class HibernateDemo {
    public static void main(String[] args) {
        User user = new User(); 
        user.setName("Angelo"); 
        user.setAge(new Long(30)); 

        // 开启Session,相当于开启JDBC的Connection
        Session session = HibernateUtil.getSessionFactory().openSession(); 
        // Transaction表示一组会话操作
        Transaction tx= session.beginTransaction(); 
        // 将物件映射至数据库表格中储存
        session.save(user);
        tx.commit(); 
        session.close(); 
        
        System.out.println("OK!用MySQL查看结果!");
        
        HibernateUtil.shutdown();
    }
}
  • HibernateDemo.java(查询)
import java.util.Iterator;

import org.hibernate.Query;
import org.hibernate.Session;

public class HibernateDemo {
    public static void main(String[] args) {
        Session session = HibernateUtil.getSessionFactory().openSession(); 
        
        // 使用HQL建立查询
        Query query = session.createQuery("from User");
        Iterator users = query.list().iterator();
        System.out.println("id \t name/age");
        while(users.hasNext()) {
            User user = (User) users.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 ?");
        // 设定查询参数
        query.setParameter(0, "Angelo");
        users = query.list().iterator();
        System.out.println("id \t name/age");
        while(users.hasNext()) {
            User user = (User) users.next(); 
            System.out.println(user.getId() +
                                " \t " + user.getName() +
                                "/" + user.getAge()); 
        }
 
        session.close();
        
        HibernateUtil.shutdown();
    }
}
Query的 setParameter()方法第一个参数是指定 ? 出现的位置,从0 开始,第二个参数则是设定查询条件。




發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章