新建一个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.sourceforge.net/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.sourceforge.net/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 (?, ?, ?)
这样子就证明你配置成功咯。