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 下载链接:
2、导入 Hibernate 的 jar 包,打开 lib 文件夹
其中,lib\required 和 lib\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约束有 DTD 和 Schema 两种,在 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" |
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】
posted on 2017-08-03 19:56 siwuxie095 阅读(174) 评论(0) 编辑 收藏 举报