初学Hibernate写一个简单的代码认识它

来源:互联网 发布:c语言错误提示 编辑:程序博客网 时间:2024/06/05 09:19

我用的是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即可
运行可以看到数据库中自建了一张表,而且还有数据。