- 开发工具:Intellij Idea 2016
- java环境:jdk1.8
- 需要的jar包:hibernate必需jar包(主角),mysql连接驱动包(数据库连接),log4j相关jar包(日志展示),junit相关jar包(简单的单元测试)
1、创建一个java项目:“xing-hibernate-stu01”
2、导入Hibernate的必需jar包
去Hibernate官网找到需要的zip文件下载,解压缩后文件结构如图:
进入到lib/required,然后复制它里面所有的文件。
3、然后项目中创建lib包,然后刚才复制的所有hibernate必需包全部复制到lib文件中,并且将lib添加到项目的classpath中。
4、下载log4j,junit,mysql相关jar包全部复制到lib文件中。
5、打开刚才下载的Hibernate解压缩文件,从路径“/project/etc”进入到etc文件中,这里有现成的hibernate配置文件,直接复制到项目中,然后修改“hibernate.cfg.xml”的内容从而变成自己项目中需要的配置文件。只保留“”结构,然后删除它里面以前原有的所有信息。然后再它里面配置自己项目需要的数据库连接的基本信息。
(如下图)
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 配置数据库方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 配置数据库连接驱动-->
<property name="hibernate.connection.driver_class" >com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://127.0.0.1:3306/test</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">root</property>
<!-- 配置打印sql -->
<property name="show_sql">true</property>
<!-- 配置 自动完成类到数据表的转换-->
<property name="hibernate.hbm2ddl.auto">update</property>
</session-factory>
</hibernate-configuration>
6、在src下创建“User”对象实体类(代码如下:)
package com.xing.entity;
import java.util.Date;
/**
* Created by Administrator on 2016/7/29.
*/
public class User {
private int id;
private String userName;
private String passWord;
private String nickName;
private Date born;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getPassWord() {
return passWord;
}
public void setPassWord(String passWord) {
this.passWord = passWord;
}
public String getNickName() {
return nickName;
}
public void setNickName(String nickName) {
this.nickName = nickName;
}
public Date getBorn() {
return born;
}
public void setBorn(Date born) {
this.born = born;
}
}
7、在User.java的当前目录创建User.hbm.xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!-- Generated Nov 9, 2006 6:27:53 PM by Hibernate Tools 3.2.0.beta7 -->
<hibernate-mapping package="com.xing.entity">
<class name="User" table="t_user" >
<id name="id">
<generator class="native"/>
</id>
<property name="userName"/>
<property name="passWord"/>
<property name="nickName"/>
<property name="born" type="timestamp"/>
</class>
</hibernate-mapping>
8、将“User.hbm.xml”数据库映射文件加入到hibernate的配置文件中。
在hibernate.cfg.xml的“”中加入如下信息:
<!-- 加入实体类的映射文件 -->
<mapping resource="com/xing/entity/User.hbm.xml"></mapping>
9、创建junit测试类。
在src下创建“test”文件夹,然后“ctrl+alt+shift+s”打开项目结构设置菜单,将“test”文件夹设置成“test sources”如下图
10、然后再test文件夹下创建测试类“TestClassTest”(这里是实现了一个简单的user的add的实现)
import com.xing.entity.User;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;
import org.junit.Test;
import java.util.Date;
import static org.junit.Assert.*;
/**
* Created by Administrator on 2016/7/29.
*/
public class TestClassTest {
@org.junit.Before
public void setUp() throws Exception {
}
@Test
public void test01(){
//创建configure对象
Configuration cfg = new Configuration().configure() ;
//创建sessionFactory、(3.0版本之前都是通过configure对象直接创建的,、
// 但是在4以后的版本都是先要创建ServiceRegistry),然后通过它来创建
ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().
applySettings(cfg.getProperties()).buildServiceRegistry();
SessionFactory factory = cfg.buildSessionFactory(serviceRegistry) ;
Session session = null ;
try {
session = factory.openSession() ;
//开启事务
session.beginTransaction() ;
User u = new User();
u.setUserName("KoBe.Bryant");
u.setPassWord("0815");
u.setNickName("科比布莱恩特");
u.setBorn(new Date());
session.save(u) ;
//提交事务
session.getTransaction().commit();
} catch (HibernateException e) {
e.printStackTrace();
} finally {
if(session!=null){
session.close() ;
}
}
}
}
这里注意jar包的正确导入
然后运行测试类,查看日志控制台:
然后再查看数据库,发现数据库中已经自动创建了表并且插入了数据
到这里基本的在hibernat的基础上,完成了一个小功能。