在Idea编辑器下编写第一个Hibernate5.x程序。

学习Hibernate了十天左右,决定开始把十来天的学习经历分享出来,方便我和后来学习的人。


File---->Java(/Java Enterprise) 选择

其他的暂时不改。

next 命名项目,finish创建项目(如果下载不下来jar包,可以使用我之后上传的5.2.11 jar包。)

然后导入mysql驱动包,(后期上传资源)。

目录结构如下

最后测试目录如下


然后新建一个xml配置文件。命名为hibernate.cfg.xml

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <!-- 我使用的是 mysql 数据库,使用其中的hib database-->
        <property name="connection.url">jdbc:mysql://localhost:3306/hib</property>
        <!-- 这是导入的MySQL 驱动包路径 -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <!-- 这是数据库账号  // / // / / / /记得更改 -->
        <property name="connection.username">root</property>
        <!-- 数据库密码   /  /记得更改为自己的密码 -->
        <property name="connection.password">root</property>

        <!-- DB schema will be updated if needed -->
        <!-- 这个update为默认选项,如果存在对应的表,则更新数据,不存在则新建 -->
        <!-- 如果为 create ,那么如果存在,则drop,然后create -->
        <property name="hbm2ddl.auto">update</property>
        
        <!-- 是否展示hibernate框架生成的数据库语句 -->
        <property name="show_sql">true</property>
        <property name="format_sql">true</property>
        
        <!-- 重要: 以下为Hibernate 使用的数据库方言,MySQL最好设计为以下,否则可能会出现很奇怪的错误 -->
        <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>

        <!--<mapping resource="Bean/User.hbm.xml"/>-->
    </session-factory>
</hibernate-configuration>
写一个实体类User

package Bean;

import javax.persistence.*;

@Entity         //注解意为:该类为“实体类”
@Table(name = "t_user")     //设计对应数据库中的table名,默认为 class 的name
public class User {
    @Id         //在
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private int id;
    @Column(name = "t_name")    //这个注解定义属性在数据表中的名称,如果没有这个注解,默认使用属性名。
    private String name;
    //手写无参构造函数
    public User() {
    }
//id为自增主键,构造方法中不提供。
    public User(String name) {
        this.name = name;
    }
//其他为get,set方法
}


然后new 一个 util 包,在util里面new一个HiberUtil类。

package Util;

//注意导包问题,自动导包可能会导错。
import Bean.User;
import org.hibernate.SessionFactory;
import org.hibernate.boot.Metadata;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;

public class HiberUtil {
    private static SessionFactory sessionFactory;

    public static SessionFactory getSessionFactory() {
        //在3.xx,4.xx版本中常用的Configuration对象获取,已经不再被推荐
        //在5.xx版本Configuration获取更改了一些API,如果仍使用Configuration方法则为
//        Configuration configuration = new Configuration().configure();
//        sessionFactory = configuration.buildSessionFactory();

        if(sessionFactory == null){
            //推荐使用以下方式
            StandardServiceRegistry standardServiceRegistry = new StandardServiceRegistryBuilder().configure().build();
            Metadata metadata = new MetadataSources(standardServiceRegistry)
                    .addAnnotatedClass(User.class)
                    .buildMetadata();
            sessionFactory = metadata.getSessionFactoryBuilder().build();
        }
        return sessionFactory;
    }
}
然后写测试类

package test;

import Bean.User;
import Util.HiberUtil;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;

public class Test01 {

    private static final SessionFactory sessionFactory = HiberUtil.getSessionFactory();
    private  static Session session = null;

    @BeforeClass
    public static void before(){
        session = sessionFactory.openSession();
        session.beginTransaction();
    }
    @Test
    public void testSomething(){
        User user1 = new User("小明");
        session.save(user1);
        session.flush();
        session.clear();
    }

    @AfterClass
    public static void Afte(){
        session.close();
        sessionFactory.close();
    }

}

进行测试,ok,数据库成功创建t_user且插入信息;





posted @ 2017-10-14 18:53  过道  阅读(120)  评论(0编辑  收藏  举报