说明:
- 一下的所有内容都是基于hibernate 5.1.x
- 开发的IDE 是 Eclipse
- 使用的数据库是 MySQL
准备
要在Eclipse 上安装 Hibernatetools ,安装方法这里不介绍。
Hibernatetools下载地址:https://sourceforge.net/projects/jboss/files/JBossTools/JBossTools4.1.x/下载hibernate
开始第一个hibernate
创建一个Java project,将hibernate 中required 文件夹下的包引入工程,但是别忘记MySQL驱动的包。
创建hibernate.cfg.xml 文件。
使用插件进行创建File
->New
->Other
->Hibernate
,选择Hibernate Configuration File(cfg.xml)
创建hibernate 配置文件。在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.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://127.0.0.1:3306/hibernate_db?useUnicode=true&characterEncoding=UTF-8</property>
<property name="connection.username">root</property>
<property name="connection.password">root</property>
<!-- 配置mysql方言 -->
<property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>
<!-- 配置是否显示SQL 语句 -->
<property name="show_sql">true</property>
<!-- 是否对SQL 进行格式化 -->
<property name="format_sql">true</property>
<!-- 指定自动生成数据库的策略-->
<property name="hbm2ddl.auto">update</property>
<!-- 指定关联的 hbm.xml -->
<mapping resource="com/cfox/hibernate/UserInfo.hbm.xml"/>
</session-factory>
</hibernate-configuration>
说明:
hbm2ddl.auto: 该属性可帮助程序员实现正向工程, 即由 java 代码生成数据库脚本, 进而生成具体的表结构 。
取值 create | update | create-drop | validate
- create : 会根据 .hbm.xml 文件来生成数据表, 但是每次运行都会删除上一次的表 ,重新生成表, 哪怕二次没有任何改变
- create-drop : 会根据 .hbm.xml 文件生成表,但是SessionFactory一关闭, 表就自动删除
- update : 最常用的属性值,也会根据 .hbm.xml 文件生成表, 但若 .hbm.xml 文件和数据库中对应的数据表的表结构不同, Hiberante 将更新数据表结构,但不会删除已有的行和列
validate : 会和数据库中的表进行比较, 若 .hbm.xml 文件中的列在数据表中不存在,则抛出异常
备注: 方言在 hibernate-release-5.1.10.Final\hibernate-release-5.1.10.Final\project\etc\
文件夹下hibernate.properties
文件中,里面有各种数据库的方言。
- 创建映射的bean
import java.sql.Date;
public class UserInfo {
private Integer id;
private String userName;
private String password;
private Date loginData;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public Date getLoginData() {
return loginData;
}
public void setLoginData(Date loginData) {
this.loginData = loginData;
}
@Override
public String toString() {
return "UserInfo [id=" + id + ", userName=" + userName + ", password=" + password + ", loginData=" + loginData
+ "]";
}
public UserInfo(String userName, String password, Date loginData) {
this.userName = userName;
this.password = password;
this.loginData = loginData;
}
public UserInfo() {
}
}
创建持久化bean需要注意一下几点:
- 提供一个无参的构造器: 使Hibernate可以使用Constructor.newInstance() 来实例化持久化类
- 提供一个标识属性(identifier property): 通常映射为数据库表的主键字段. 如果没有该属性,一些功能将不起作用,如:Session.saveOrUpdate()
- 为类的持久化类字段声明访问方法(get/set): Hibernate对JavaBeans 风格的属性实行持久化。
- 使用非 final 类: 在运行时生成代理是 Hibernate 的一个重要的功能. 如果持久化类没有实现任何接口, Hibnernate 使用 CGLIB 生成代理. 如果使用的是 final 类, 则无法生成 CGLIB 代理.
- 重写 eqauls 和 hashCode 方法: 如果需要把持久化类的实例放到 Set 中(当需要进行关联映射时), 则应该重写这两个方法
为创建的bean创建映射文件
使用插件创建方法:File
->New
->Other
->Hibernate
,选择Hibernate mapping File (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-10-12 18:13:29 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
<class name="com.cfox.hibernate.UserInfo" table="USER_INFO">
<id name="id" type="java.lang.Integer">
<column name="ID" />
<!-- 指定主键的生成方式, native : 使用数据库本地的方式-->
<generator class="native" />
</id>
<property name="userName" type="java.lang.String">
<column name="USERNAME" />
</property>
<property name="password" type="java.lang.String">
<column name="PASSWORD" />
</property>
<property name="loginData" type="java.sql.Date">
<column name="LOGINDATA" />
</property>
</class>
</hibernate-mapping>
在映射文件中配置的是数据表相关的内容:
class
标签配置表和实体bean的关系, name
对应实体bean , table
对应数据库中表名。
property
标签中 name
属性是对应bean中的变量 type
则对应类型。
column
标签中 name
属性则是指定在数据库中表名。
执行保存动作
hibernate 4.2.x 和 hibernate 5.1.x 有所不同,这里就都说一下
hibernate 4.2.x
- 创建SessionFactory 对象
- 创建Configuration 对象
- 创建ServiceRegistry 对象
- 创建SessionFactory 对象
- 创建Session 对象
- 开启事务
- 执行动作
- 提交事务
- 关闭Session
- 关闭SessionFactory
public class TestTools {
@Test
public void test() {
//1. 创建一个 SessionFactory 对象
SessionFactory sessionFactory = null;
//1). 创建 Configuration 对象: 对应 hibernate 的基本配置信息和 对象关系映射信息
Configuration configuration = new Configuration().configure();
//4.0 之前这样创建
//sessionFactory = configuration.buildSessionFactory();
//2). 创建一个 ServiceRegistry 对象: hibernate 4.x 新添加的对象
//hibernate 的任何配置和服务都需要在该对象中注册后才能有效.
ServiceRegistry serviceRegistry =
new ServiceRegistryBuilder().applySettings(configuration.getProperties())
.buildServiceRegistry();
//3).
sessionFactory = configuration.buildSessionFactory(serviceRegistry);
//2. 创建一个 Session 对象
Session session = sessionFactory.openSession();
//3. 开启事务
Transaction transaction = session.beginTransaction();
//4. 执行保存操作
News news = new News("Java12345", "ATGUIGU", new Date(new java.util.Date().getTime()));
session.save(news);
//5. 提交事务
transaction.commit();
//6. 关闭 Session
session.close();
//7. 关闭 SessionFactory 对象
sessionFactory.close();
}
}
hibernate 5.1.x
- 创建SessionFactory 对象
- 创建 StandardServiceRegistry 对象
- 创建SessionFactory 对象
- 创建Session 对象
- 开启事务
- 执行动作
- 提交事务
- 关闭Session
- 关闭SessionFactory
public class TestTools {
@Test
public void testUserInfo() {
//1.创建sessionFactory 对象
SessionFactory sessionFactory = null;
//1)创建 StandardServiceRegistry 对象
StandardServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().configure().build();
//2)
sessionFactory = new MetadataSources(serviceRegistry).buildMetadata().buildSessionFactory();
//2. 创建一个 Session 对象
Session session = sessionFactory.openSession();
//3. 开启事务
Transaction transaction = session.beginTransaction();
//4. 执行保存操作
UserInfo userInfo = new UserInfo("张三", "123456", new Date(new java.util.Date().getTime()));
session.save(userInfo);
//5. 提交事务
transaction.commit();
//6. 关闭 Session
session.close();
//7. 关闭 SessionFactory
sessionFactory.close();
}
}