分享

Java配置Hibernate详细教程_Hibernate_Java中文网

 sofes 2011-05-22

Java配置Hibernate详细教程

作者:JAVA中文网发布时间:2010-09-13来源:会员投稿 点我投稿

新建一个java工程

导入所需的jar包,有:

--------------------------------------------

hibernate3.jar,

antlr-2.7.6.jar,

commons-collections-3.1.jar,

dom4j-1.6.1.jar,

javassist-3.9.0.jar,

jta-1.1.jar,

slf4j.api-1.5.8.jar,

slf4j-nop-1.5.8.jar

--------------------------------------------

如果是使用Annotation的话,还需导入以下jar包:

--------------------------------------------

hibernate-annotations.jar

hibernate-commons-annotations.jar

ejb3-persistence.jar

--------------------------------------------

新建一个类作为学生模型:Student.java,代码如下:

 

package com.hzucmj.hibernate.model;

public class Student {
private int id;
private String name;
private int age;
public int getId() {
return id;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
public void setId(int id) {
this.id = id;
}
public void setName(String name) {
this.name = name;
}
public void setAge(int age) {
this.age = age;
}
}

 

 在Student.java的同个目录下再创建该类的映射文件:Student.hbm.xml,内容如下:(内容可以在hibernate的api文档里面copy,没必要自己敲啦,谁敲谁傻瓜)

 

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate./hibernate-mapping-3.0.dtd"
>

<hibernate-mapping package="com.hzucmj.hibernate.model"><!-- 这里的package记得要写对啊。要不然运行也会出错的 -->
<class name="Student" table="student"><!-- 如果表名跟类名一个样的话,那么table属性可以不写 -->
<id name="id"></id>
<property name="name"></property>
<property name="age"></property>
</class>
</hibernate-mapping>

 

 在src目录下新建一个hibernate的配置文件hibernate.cfg.xml,其内容如下:(内容可以在hibernate的api文档里面copy,同样,谁敲谁傻瓜)

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

<hibernate-configuration>

<session-factory>

<!-- Database connection settings -->
    <!-- 选择数据库驱动,如果是mysql的话,改成com.mysql.jdbc.Driver -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>  
  <property name="connection.url">jdbc:mysql://localhost/hibernate</property>
<property name="connection.username">root</property>
<property name="connection.password">123456</property>

<!-- JDBC connection pool (use the built-in) -->
<property name="connection.pool_size">1</property>

<!-- SQL dialect -->
    <!-- 选择sql语言,如果是mysql的话,改成org.hibernate.dialect.MySQLDialect -->
<property name="dialect">org.hibernate.dialect.HSQLDialect</property>

<!-- Enable Hibernate's automatic session context management -->
<property name="current_session_context_class">thread</property>

<!-- Disable the second-level cache -->
<property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>

<!-- Echo all executed SQL to stdout -->
<property name="show_sql">true</property>

<!-- Drop and re-create the database schema on startup -->
  <!-- 
   写update只是更新操作,也可以写create,
这样写create的话程序运行的时候就会把数据库里的内容全部删除并且重新创建,
当然,前提是数据库必须存在,因为hibernate只会创建表结构,
不会创建数据库,如果指定的数据库不存在,hibernate则会抛出异常 
-->
<property name="hbm2ddl.auto">update</property>

<mapping resource="com/hzucmj/hibernate/model/Student.hbm.xml"/>
     <!-- 
      这里需要注意的是,如果你是使用Annotation的话,那就应该写成
      <mapping class = "com.hzucmj.hibernate.Student" />
     -->
</session-factory>

</hibernate-configuration>

 再新建一个java文件StudentTest.java,测试连接成功了没,代码如下:

 

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

import com.hzucmj.hibernate.model.Student;


public class StudentTest {
public static void main(String[] args) {
Student s
= new Student();
s.setId(
1);
s.setAge(
23);
s.setName(
"hzucmj");

Configuration cfg
= new Configuration();
SessionFactory sf
= cfg.configure().buildSessionFactory();
Session session
= sf.openSession();
session.beginTransaction();
session.save(s);
session.getTransaction().commit();
session.close();
sf.close();
}

}

 

 如果配置成功的话,那么在调试窗口会出现如下的信息:

Hibernate: insert into student (name, age, id) values (?, ?, ?)

这样子就证明你配置成功咯。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多