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 要求实体类有一个属性唯一,即主键

privateint uid;

private String username;

private String password;

private String address;

 

publicint getUid() {

return uid;

}

publicvoid setUid(int uid) {

this.uid = uid;

}

public String getUsername() {

return username;

}

publicvoid setUsername(String username) {

this.username = username;

}

public String getPassword() {

return password;

}

publicvoid setPassword(String password) {

this.password = password;

}

public String getAddress() {

return address;

}

publicvoid 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 中添加如下约束:

  

<?xmlversion="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:

  

<?xmlversion="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 自动生成) -->

<classname="com.siwuxie095.entity.User"table="t_user">

 

<!-- (2)

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

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

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

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

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

<idname="uid"column="uid">

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

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

<generatorclass="native"></generator>

</id>

 

<!-- (3)

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

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

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

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

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

<propertyname="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 中添加如下约束:

  

<?xmlversion="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:

  

<?xmlversion="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>

 

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

 

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

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

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

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

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

 

 

 

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

 

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

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

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

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

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

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

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

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

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

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

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

 

 

 

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

<mappingresource="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

publicvoid 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】

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值