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

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

发布了64 篇原创文章 · 获赞 42 · 访问量 7万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章