其实java配置hibernate也并不是很难,主要是设置方面有些是要注意下,要不然就很容易出错了,之前配置过一次,可以运行。系统重装后,刚又配置了,却不能运行,几经折腾,才知道搞错了。
现在把配置过程写一下,以免自己以后又搞错了。
新建一个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 (?, ?, ?)
这样子就证明你配置成功咯。
本文详细介绍如何在Java项目中配置Hibernate框架,包括所需依赖、模型类定义、映射文件及配置文件的编写,并提供测试示例。

&spm=1001.2101.3001.5002&articleId=7733012&d=1&t=3&u=c607096aa72045788ca9e89325a0e252)
7989





