我用的是MyEclipse,有些插件有,但还是要说一下,用Eclipse也是一样的,先做一些前期工作,上面文章我们说过如何下载Hibernate插件,下载过来后我们解压得到如图:
将第二个ZIP文件安装在Eclipse即可
这里要说一下,安装是下面两个插件我这里安装出问题了,只安装了下面两个,然后建工程文件的时候不能点完成,建不了文件,后来我直接把如图文件下的两个目录文件下的文件复制到了Eclipse的对应的文件名称里面就OK了。然后就TMD可以了。
接下来认识一下目录文件如下图
按图上的顺序建的文件
还有要导入JAR包与对应的数据库JAR驱动
如图
放在对应的lib目录就行,因为我这里是WEB工程目录,java工程也是翻放在lib目录下,接下来就是右键-Build path加入所有JAR包到工程
好了,准备工作完成开始配置
首先我们建一个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>
<!-- 配置连接数据库的基本信息 -->
<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/hibtest</property>
<!-- 配置hibernatenate 的基本信息 -->
<!-- hibernate 所使用的数据库方言 -->
<property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
<!-- 执行操作时是否在控制台打印SQL -->
<property name="show_sql">true</property>
<!-- 是否对SQL进行格式化 -->
<property name="format_sql">true</property>
<!-- 指定自动生成数据表的策略 -->
<property name="hbm2ddl.auto">update</property>
<!-- 设置Hibernate 的事务隔离级别-->
<property name="connection.isolation">2</property>
<!-- 指定关联的.hbm.xml文件 -->
<mapping resource="com/hib/helloworld/News.hbm.xml"/>
</session-factory>
</hibernate-configuration>
我这里的数据库方言用的是MySql5.1之后的,要不会出一些语法错误
接下来复制
http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd
左键-windos-preferences-XML-XML Catalog
然后选择User Specified Entries点击Add后如下图
选择图片里的.dtd文件与录入上面的Http字符串即可,
这样hibernate配置完成。
下面新建News.java类,代码如下
package com.hib.helloworld;
import java.sql.Date;
public class News {
private Integer id;
private String title;
private String author;
private Date date;
public News() {
}
public News(String title, String author, Date date) {
this.title = title;
this.author = author;
this.date = date;
}
@Override
public String toString() {
return "News [id=" + id + ", title=" + title + ", author=" + author + ", date=" + date + "]";
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getAuthor() {
return author;
}
public void setAuthor(String author) {
this.author = author;
}
public Date getDate() {
return date;
}
public void setDate(Date date) {
this.date = date;
}
}
然后新建News.hbm.xml文件
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2017-7-17 17:38:39 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
<class name="com.hib.helloworld.News" table="NEWS">
<id name="id" type="java.lang.Integer">
<column name="ID" />
<!-- 指定主键的生成方式,native:使用数据库本地的方式-->
<generator class="native" />
</id>
<property name="title" type="java.lang.String">
<column name="TITLE" />
</property>
<property name="author" type="java.lang.String">
<column name="AUTHOR" />
</property>
<property name="date" type="java.sql.Date">
<column name="DATE" />
</property>
</class>
</hibernate-mapping>
然后新建测试类HibTest.java,代码如下
package test;
import java.sql.Date;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.junit.Test;
import com.hib.helloworld.News;
public class HibTest {
public void init(){
}
public void destore(){
}
@Test
public void test() {
//1.创建一个SessionFactory 对像
SessionFactory sessionFactory = null;
//1).创建Configuration对象:对应hibernate的基本配置信息和对象关系映射信息
Configuration configuration = new Configuration().configure();
//2).创建一个ServiceRegistry 对象:hibernate 4.x新添加的对象
//hibernate的任何配置和服务都需要在该对象中注册后才能有效
StandardServiceRegistry standardRegistry = new StandardServiceRegistryBuilder().configure().build();
//3).创建会话工厂对象
sessionFactory = configuration.buildSessionFactory(standardRegistry);
//2.创建一个Session对象
Session session = sessionFactory.openSession();
//3.开启事物
Transaction transaction = session.beginTransaction();
//4.执行保存操作
News news = new News("Java","ATGUGI",new Date(new java.util.Date().getTime()));
session.save(news);
//5.提交事物
transaction.commit();
//6.关闭Session
session.close();
//7.关闭SessionFactory
sessionFactory.close();
}
}
在数据库建一个对应的datebase即可
运行可以看到数据库中自建了一张表,而且还有数据。