首页 > 代码库 > Hibernate入门

Hibernate入门

-------------------------siwuxie095

   

   

   

   

   

   

   

   

搭建 Hibernate 环境

   

   

1、先下载相关库文件,下载链接:

   

http://hibernate.org/orm/downloads/

   

   

注意:这里选择下载 Hibernate 5.0 版本(或 5.1 亦可),

下载后,将 hibernate-release-5.0.12.Final.zip 解压一览:

   

技术分享

   

   

   

hibernate-release-5.0.12.Final.zip 下载链接:

   

https://sourceforge.net/projects/hibernate/files/hibernate-orm/5.0.12.Final/hibernate-release-5.0.12.Final.zip/download

   

   

   

2、导入 Hibernate 的 jar 包,打开 lib 文件夹

   

技术分享

   

   

其中,lib\requiredlib\jpa 文件夹中的包(共 10 个包)必须要导入

   

技术分享

   

技术分享

   

   

   

3、在使用 Hibernate 时,有日志信息输出,而 Hibernate 本身

并没有日志输出的包,所以还要导入其它日志相关的包,如下:

   

1)slf4j-api

   

2)slf4j-log4j

   

3)log4j

   

   

SLF4J 下载链接:https://www.slf4j.org/dist/,其中包含 slf4j-api

和 slf4j-log4j

   

   

LOG4J 下载链接:https://www.apache.org/dist/logging/log4j/,

其中包含 log4j

   

   

其实,Hibernate的 lib\optional\ehcache 文件夹下也有 slf4j-api:

   

技术分享

   

   

   

4、最后,需要下载 MySQL 的 JDBC 驱动,下载链接:

   

https://dev.mysql.com/downloads/connector/j/

   

其中,包含:mysql-connector-java

   

   

另外,其 src\lib 文件夹下,也有 slf4j-api:

   

技术分享

   

   

   

5、综上所述,共需 14 jar 包

   

技术分享

   

   

   

   

   

   

   

创建实体类

   

   

包名:com.siwuxie095.entity

类名:User.java

   

   

User.java:

   

package com.siwuxie095.entity;

   

public class User {

   

//Hibernate 要求实体类有一个属性唯一,即主键

private int uid;

private String username;

private String password;

private String address;

 

public int getUid() {

return uid;

}

public void setUid(int uid) {

this.uid = uid;

}

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 String getAddress() {

return address;

}

public void setAddress(String address) {

this.address = address;

}

 

 

 

}

   

   

注意:使用 Hibernate 时,不需要自己手动创建表,Hibernate

可以帮助我们把表自动创建出来

   

   

   

   

   

   

   

创建 Hibernate 的映射配置文件

   

   

配置实体类和数据库表一一对应关系(使用配置文件实现映射关系)

   

   

1、创建 XML 格式的配置文件

   

映射配置文件的名称和位置没有固定要求

   

建议:在实体类所在包里创建,名称为:实体类名.hbm.xml

   

hbm,即 Hibernate Mapping」

   

具体到这里,即 在 com.siwuxie095.entity 包下创建 User.hbm.xml

   

   

   

2、在配置文件中引入 XML 约束

   

hibernate-mapping-3.0.dtd

   

「XML约束有 DTDSchema 两种,在 Hibernate 的配置文件

中引入的是 DTD 约束(目前)」

   

   

该文件在 project\hibernate-core\src\main\resources\org\hibernate 文件夹下:

   

技术分享

   

   

   

User.hbm.xml 中添加如下约束:

   

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE hibernate-mapping PUBLIC

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

   

   

   

3、配置映射关系

   

User.hbm.xml:

   

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE hibernate-mapping PUBLIC

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

   

<!--

http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd

 

dtd 文件是用于提示的文件,联网即有提示信息,也可

手动添加:Window->Preferences->XML->XML Catalog

点击 Add 添加即可,Location 即路径,Key 即上面的链接,

Key type URI

-->

 

<!-- 根标签 -->

<hibernate-mapping>

   

<!-- (1)

class 标签:配置实体类和数据库表的对应;

name 属性:实体类的全路径,即全限定名;

table 属性:数据库表的名称(数据库表由 Hibernate 自动生成) -->

<class name="com.siwuxie095.entity.User" table="t_user">

 

<!-- (2)

id 标签:配置实体类 id 和表 id 对应(主键);

name 属性:实体类里 id 属性名称;

column 属性:生成表中 id 字段名称 -->

<!-- Hibernate 要求实体类有一个属性唯一值,

Hibernate 要求表中字段有一个属性唯一值 -->

<id name="uid" column="uid">

<!-- 设置数据库表 id 的增长策略,

native:主键 id 值自动增长 -->

<generator class="native"></generator>

</id>

 

<!-- (3)

property 标签:配置其它属性和表中字段对应;

name 属性:实体类属性名称;

column 属性:生成表中字段名称 -->

<property name="username" column="username"></property>

<property name="password" column="password"></property>

<property name="address" column="address"></property>

</class>

   

</hibernate-mapping>

   

   

   

   

   

   

   

创建 Hibernate 的核心配置文件

   

   

1、创建 XML 格式的配置文件

   

核心配置文件的名称和位置是固定的

   

位置:必须在 src

   

名称:必须是 hibernate.cfg.xml

   

「cfg,即 Configuration」

   

   

   

2、在配置文件中引入 XML 约束

   

hibernate-configuration-3.0.dtd

   

   

hibernate.cfg.xml 中添加如下约束:

   

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE hibernate-configuration PUBLIC

"-//Hibernate/Hibernate Configuration DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

   

   

   

3、在核心配置文件中进行相关配置

   

第一部分:配置数据库信息(必须)

   

第二部分:配置 Hibernate 信息(可选)

   

第三部分:引入映射配置文件,把映射文件放到核心配置文件中(必须)

   

注意:Hibernate 在操作过程中,只会加载核心配置文件,其它配置文件

不会进行加载

   

   

hibernate.cfg.xml:

   

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE hibernate-configuration PUBLIC

"-//Hibernate/Hibernate Configuration DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

 

<!-- 根标签 -->

<hibernate-configuration>

<session-factory>

 

<!-- 第一部分:配置数据库信息(必须) -->

 

<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>

<!-- 或使用 jdbc:mysql:///hibernate_db 代替,省略 localhost -->

<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_db</property>

<property name="hibernate.connection.username">root</property>

<property name="hibernate.connection.password">8888</property>

 

 

 

<!-- 第二部分:配置 Hibernate 信息(可选) -->

 

<!-- 输出底层 sql 语句 -->

<property name="hibernate.show_sql">true</property>

<!-- 输出底层 sql 语句格式 -->

<property name="hibernate.format_sql">true</property>

<!-- Hibernate 帮助创建表,不是自动创建,而需要配置之后。

update:如果已经有表,就更新,如果没有,就自动创建 -->

<property name="hibernate.hbm2ddl.auto">update</property>

<!-- 配置数据库方言,让 Hibernate 框架识别不同数据库自己特有的语句。

如:在 MySQL 中实现分页的关键字 limit,只能在 MySQL 中使用,而

Oracle 中实现分页的关键字则是 rownum -->

<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>

 

 

 

<!-- 第三部分:引入映射配置文件,把映射配置文件放到核心配置文件(必须) -->

<mapping resource="com/siwuxie095/entity/User.hbm.xml"/>

</session-factory>

</hibernate-configuration>

   

   

   

注:hibernate.properties 在 project\etc 文件夹下

   

技术分享

   

   

   

   

   

   

   

测试:实现添加操作

   

   

第一步:加载 Hibernate 核心配置文件

   

第二步:创建 SessionFactory 对象

   

第三步:使用 SessionFactory 创建 Session 对象

   

第四步:开启事务

   

第五步:编写具体逻辑:CRUD 操作

   

第六步:提交事务

   

第七步:关闭资源

   

   

「注意:只有第五步是变化的」

   

   

包名:com.siwuxie095.hibernatetest

类名:HibernateDemo.java

   

   

HibernateDemo.java:

   

package com.siwuxie095.hibernatetest;

   

import org.hibernate.Session;

import org.hibernate.SessionFactory;

import org.hibernate.Transaction;

import org.hibernate.cfg.Configuration;

import org.junit.Test;

   

import com.siwuxie095.entity.User;

   

public class HibernateDemo {

   

//手动加上 @Test 以进行单元测试(将自动导入 JUnit 4

// jar 包)

//

//选中方法名,右键->Run As->JUint Test

@Test

public void addTest(){

 

//第一步:加载 Hibernate 核心配置文件

//

//因为核心配置文件的名称和位置是固定的,所以会到

//src 下找到 hibernate.cfg.xml 放到 cfg 对象中

Configuration cfg=new Configuration();

cfg.configure();

 

 

//第二步:创建 SessionFactory 对象

//

//读取核心配置文件的内容,创建 SessionFactory

//在创建的过程中,会根据映射关系,在数据库中将

//表创建出来

//

//调用 cfg buildSessionFactory() 方法,返回

//值是 SessionFactory 类型,创建以接收

SessionFactory sessionFactory=cfg.buildSessionFactory();

 

   

//第三步:使用 SessionFactory 创建 Session 对象

//

//类似于 JDBC 中的连接 Connection

//

//调用 sessionFactory openSession() 方法,返

//回值是 Session 类型,创建以接收

Session session=sessionFactory.openSession();

 

   

//第四步:开启事务

//

//调用 session beginTransaction() 方法,返回

//值是 Transaction 类型,创建以接收

Transaction tx=session.beginTransaction();

   

 

//第五步:编写具体逻辑:CRUD 操作

User user=new User();

user.setUsername("小明");

user.setPassword("8888");

user.setAddress("中国");

//调用 session save() 方法实现添加

session.save(user);

 

 

//第六步:提交事务

tx.commit();

   

 

//第七步:关闭资源

session.close();

sessionFactory.close();

   

}

}

   

   

运行一览:

   

1)控制台:

   

技术分享

   

   

2)数据库:

   

技术分享

   

技术分享

   

   

   

   

   

工程结构目录一览:

   

技术分享

   

技术分享

   

   

   

   

   

   

   

   

   

   

   

【made by siwuxie095】

Hibernate入门