在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且插入信息;